LA 3942 Remember the Word

(Remember the Word ,LA 3942) 

题目来源:https://vjudge.net/problem/UVALive-3942

题意:给定一个字符串S以及n个单词,字符用这n个单词进行拆分,输出拆分的方案数。

思路:dp+字典树

可以先将这n个单词存储于字典树中,并记dp[i]:字符i开始的字符串的分解方案数量(即后缀S[i...end]),则动态转移方程为dp[i]=sum{dp[i+len(x)] | 单词x是S[i...end]的前缀}.

找S[i...end]的前缀可以在字典树中查找。

AC代码:

#define _CRT_SECURE_NO_DEPRECATE
#include<iostream>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<vector>
#include<string>
#include<iomanip>
#include<map>
#include<stack>
#include<set>
#include<queue>
#include<cstdio>
using namespace std;
#define N_MAX 4000+5
#define L_MAX 4000*100+5
#define INF 0x3f3f3f3f
#define MOD 20071027
typedef long long ll;
int n;
int dp[L_MAX];
int len[N_MAX];
char S[L_MAX];
struct Trie {int ch[L_MAX][26];int val[L_MAX];int sz;Trie() { sz = 1; memset(ch[0], 0, sizeof(ch[0])); }void init() { sz = 1; memset(ch[0], 0, sizeof(ch[0])); }int idx(char c) { return c - 'a'; }void insert(char*s, int v) {int u = 0, n = strlen(s);for (int i = 0; i < n; i++) {int c = idx(s[i]);if (!ch[u][c]) {memset(ch[sz], 0, sizeof(ch[sz]));val[sz] = 0;ch[u][c] = sz++;}u = ch[u][c];}val[u] = v;}//找长度为len的字符串s的前缀void find(char *s, int len, vector<int>&ans) {int u = 0;for (int i = 0; i < len; i++) {if (s[i] == '\0')break;int c = idx(s[i]);if (!ch[u][c]) break;u = ch[u][c];if (val[u] != 0)ans.push_back(val[u]);}}
};Trie trie;//不要放到main()下int main() {int Case = 1;while (scanf("%s%d", S, &n) !=EOF) {memset(dp, 0, sizeof(dp));trie.init();for (int i = 1; i <= n; i++) {char x[100];scanf("%s", x);len[i] = strlen(x);trie.insert(x, i);//将单词存入字典树,单词编号为i
        }int L = strlen(S);dp[L] = 1;for (int i = L - 1; i >= 0; i--) {vector<int>ans;//存储单词的编号trie.find(S + i, L - i, ans);for (int j = 0; j < ans.size(); j++) {dp[i] = (dp[i] + dp[i + len[ans[j]]]) % MOD;}}printf("Case %d: %d\n", Case++, dp[0]);}return 0;
}

 

转载于:https://www.cnblogs.com/ZefengYao/p/8516576.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/466525.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网线水晶头的接法

网线水晶头的接法网线水晶头的接法 制作线的时候&#xff0c;有一个一般性的原则就是&#xff1a; 同类&#xff08;连接线的两端是同一种设备&#xff09;交叉&#xff08;做交叉线&#xff09; 异类&#xff08;连接线的两端是不同的设备&#xff09;平行&#xff08;作平行线…

C++的Json解析库:jsoncpp和boost

JSON(JavaScript Object Notation)跟xml一样也是一种数据交换格式&#xff0c;了解json请参考其官网http://json.org&#xff0c;本文不再对json做介绍&#xff0c;将重点介绍c的json解析库的使用方法。json官网上列出了各种语言对应的json解析库&#xff0c;作者仅介绍自己使用…

电子工程师都在看什么?送你一份“修炼宝典”

现如今&#xff0c;形形色色的公众号如繁星一般让人眼花缭乱。近几年科技的飞速发展&#xff0c;让更多人开始关注科技&#xff0c;甚至成为极客。然而学习是永无止境的&#xff0c;如何才能追赶如此高速的发展&#xff1f;曾经&#xff0c;我也是不知道去看哪些&#xff0c;便…

DataCleaner(4.5)第一章

Part1. Introduction to DataCleaner  介绍DataCleaner |--What is data quality(DQ)  数据质量&#xff1f;|--What is data profiling?   数据分析&#xff1f;|--What is datastore?     数据存储&#xff1f;   Composite datastore   综合性数据存储 |…

Oracle数据库管理员职责(二)

DBA日常管理 目的&#xff1a;这篇文档有很详细的资料记录着对一个甚至更多的ORACLE数据库每天的&#xff0c;每月的&#xff0c;每年的运行的状态的结果及检查的结果&#xff0c;在文档的附录中你将会看到所有检查&#xff0c;修改的SQL和PL/SQL代码。目录1.日常维护程序A.检查…

c100道

题目来源&#xff1a; 1、中兴、华为、慧通、英华达、微软亚洲技术中心等中 外企业面试题目&#xff1b; 2、C 语言面试宝典(林锐《高质量编程第三版》)。 说明&#xff1a; 1、部分C 语言面试题中可能会参杂部分和C 相关的知 识&#xff0c;为了保持题目的灵活性故保留&#x…

约瑟夫斯问题-java版数组解法和链表解法

10个人围成一圈&#xff0c;从1到10编号&#xff0c;从1开始数&#xff0c;数到3或3的倍数的位置&#xff0c;则该位置的人出局&#xff0c;求最后剩下哪一个号&#xff1f; 数组解法&#xff1a; 数组存放数组&#xff1a;a[10]存在1到10编号人 数组遍历到尾部又从头遍历&…

少写点if-else吧,它的效率有多低你知道吗?

# 干了这碗鸡汤我要再和生活死磕几年。要么我就毁灭&#xff0c;要么我就注定铸就辉煌。如果有一天&#xff0c;你发现我在平庸面前低了头&#xff0c;请向我开炮。--杰克凯鲁亚克if-else涉及到分支预测的概念&#xff0c;关于分支预测上篇文章《虚函数真的就那么慢吗&#xff…

js实现连接的两种放法

第一种用document.write输出 <html> <body> <script type"text/javascript"> var rMath.random() if (r>0.5) { document.write("<a hrefhttp://www.w3school.com.cn>学习 Web 开发&#xff01;</a>") } else { documen…

异或求校验和

uint8_t chk_xrl(const void *data, uint16_t length) {const uint8_t *buf data;uint8_t retval 0;while(length){retval ^ *buf;--length;}return retval; }

c语言笔试

1、局部变量能否和全局变量重名&#xff1f;   答&#xff1a;能&#xff0c;局部会屏蔽全局。要用全局变量&#xff0c;需要使用"::" ;局部变量可以与全局变量同名&#xff0c;在函数内引用这个变量时&#xff0c;会用到同名的局部变量&#xff0c;而不会用到全局…

聚宝盆,只要你上网就可以挣钱

点此注册[url]http://www.56cash.com/ref.php?id5429[/url]转载于:https://blog.51cto.com/435178/100909

为什么不能在中断上半部休眠?

这是一个老生常谈的问题。我们先简单说下什么是中断「因为最近在群里看到有人竟然不懂什么是中断」。中断是计算机里面非常核心的东西&#xff0c;我们可以跑OS&#xff0c;可以多任务运行都因为中断的存在。假设你是一个CPU&#xff0c;你正在睡觉。你突然觉得肚子疼&#xff…

打CALL APP 项目进展 总体计划

时间进展完成度参与人员备注2018.3完成app的前端设计 全体 2018.4app的后端 2018.5app的后端 转载于:https://www.cnblogs.com/aliceluorong/p/8520442.html

单片机中通用的类型别名

单片机中通用的类型别名 #ifndef _TYPE_H_ #define _TYPE_H_#ifdef __GNUC__ #define __packed __attribute__((aligned(1))) #endif/* exact-width signed integer types */ typedef signed char int8_t; typedef signed short int int16_t; typedef sign…

j.u.c系列(08)---之并发工具类:CountDownLatch

写在前面 CountDownLatch所描述的是”在完成一组正在其他线程中执行的操作之前&#xff0c;它允许一个或多个线程一直等待“&#xff1a;用给定的计数 初始化 CountDownLatch。由于调用了 countDown() 方法&#xff0c;所以在当前计数到达零之前&#xff0c;await 方法会一直受…

巧用1个GPIO控制2个LED显示4种状态

很多电子产品有状态指示灯&#xff0c;比如电视机&#xff1a;待机状态亮红灯开机状态亮绿灯实现起来很简单&#xff0c;微控制器MCU的两个GPIO分别控制就行&#xff1a;不过资源总是紧张的&#xff0c;有时候会碰到GPIO不够用的情况。如果只用1个GPIO&#xff0c;可不可以实现…

GetTickcount函数

GetTickCount是一种函数。GetTickCount返回&#xff08;retrieve&#xff09;从操作系统启动所经过&#xff08;elapsed&#xff09;的毫秒数&#xff0c;它的返回值是DWORD。 GetTickcount函数&#xff1a;它返回从操作系统启动到当前所经过的毫秒数&#xff0c;常常用来判断某…

网络大小端转换函数

网络大小端转换函数 //***************************************************************************** // // htonl/ntohl - big endian/little endian byte swapping macros for // 32-bit (long) values // //**********************************************************…

5-全排列总结:

https://www.nowcoder.com/acm/contest/76/H 给一道题&#xff0c;可以去测试代码。 这里总结一下全排列的几种方法&#xff1a; 方法一&#xff1a;利用交换排列&#xff1a;缺点&#xff1a;不能按字典序排列&#xff0c;但可以借助set处理。 #include <bits/stdc.h> …