就像每个人都会遇到的问题一样,贝西忘了在 cowtube 上的口令。不过,她还记着一些关于口令

的信息。首先,她确定口令由小写字母组成,长度为 L。其次,这个密码是由几个单词组合而成

的。贝西一共认识 N 个单词,每个单词长度都在 1 到 20 之间,由小写字母组成。最后,贝西还

记得口令上一些位置的字母,她会尽量提供记住的部分,如果有些位置上的字母不记得了,就用?

代替。

给定贝西记得的口令片段和她认识的单词列表,请恢复出她的口令,如果完全符合条件的口令不

止一个,输出按照字典序排在最前面的那个。

输入输出格式

输入格式:

第一行:两个用空格分开的整数:L 和 N,1≤L≤1000,1≤N≤1000

第二行:一个 L 长的字符串,代表口令 P

第三行到 N+2 行:第 i+2 有一个字符串 W_i,表示贝西认识的第 i 个单词 W_i

输出格式:

第一行:一个字符串,表示符合条件的,在字典序下最靠前的口令

输入输出样例

输入样例#1:

15 6
a??l?ban???????
apple
cow
farmer
banana
bananas
pies
输出样例#1:

applebananapies
样例解释
(有两个可行的组合,一个是 applebananapies,还有一个是 applebananascow,前者较靠前)

说明

对于 30% 的数据,有 1 ≤ L,N≤ 30。

对于 100% 的数据,有 1 ≤ L,N≤ 1, 000。

分析:万万没想到这道题还能用dp做,大开眼界啊,但是时间紧直接打了个暴力还有20分?

其实这道题很像0-1背包啊,每个口令的容积就是它的长度,价值就是它的字典序的贡献,只不过多了几个限制,最关键的是字符串中间一定不能有空串,也就是说不能拼接成apple  banana这样的,所以要加一个特判,dp就很好想啦,设f[i]为前i个字符的组合,那么f[i] = min{f[i-j.size()] + j}.

这种字符串的下标处理真的是超级超级烦人.

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<cmath>
#include<map>
#include<string> using namespace std; int l, n;
string p,w[],f[]; bool check(int x, int y)
{
for (int i = x - w[y].size() + , j = ; i <= x; i++, j++)
if (p[i] != '?' && p[i] != w[y][j])
return false;
return true;
} int main()
{
scanf("%d%d", &l, &n);
cin >> p;
for (int i = ; i <= n; i++)
cin >> w[i];
for (int i = ; i <= l; i++)
for (int j = ; j <= n; j++)
{
int sizee = w[j].size();
if (sizee > i || (f[i - sizee] == "" && i - sizee != ))
continue;
if (check(i - , j))
{
if (f[i] == "")
f[i] = f[i - sizee] + w[j];
else
f[i] = min(f[i], f[i - sizee] + w[j]);
}
}
cout << f[l] << endl; return ;
}

常州模拟赛d1t5 遗忘口令的更多相关文章

  1. 常州模拟赛d4t1 立方体

    题目描述 立方体有 6 个面,每个面上有一只奶牛,每只奶牛都有一些干草.为了训练奶牛的合作精神,它 们在玩一个游戏,每轮:所有奶牛将自己的干草分成 4 等份,分给相邻的 4 个面上的奶牛. 游戏开始, ...

  2. 常州模拟赛d7t3 水管

    分析:第一问还是很好做的,关键是怎么做第二问.我们可以每次删掉最小生成树上的一条边,然后再求一次最小生成树,看边权和大小和原来的是不是一样的,不过这个做法效率很低. 考虑Kruskal算法的原理,每次 ...

  3. 常州模拟赛d6t3 噪音

    FJ有M个牛棚,编号1至M,刚开始所有牛棚都是空的.FJ有N头牛,编号1至N,这N头牛按照编号从小到大依次排队走进牛棚,每一天只有一头奶牛走进牛棚.第i头奶牛选择走进第p[i]个牛棚.由于奶牛是群体动 ...

  4. bzoj3743 [Coci2015]Kamp 常州模拟赛d6t2

    3743: [Coci2015]Kamp Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 484  Solved: 229[Submit][Status ...

  5. 常州模拟赛d5t2 mogician

    分析:一个暴力的思想是枚举g,然后枚举每个数ai,看能不能符合要求,这样复杂度是O(nA)的,直接T掉了.也没什么其他的办法了,在暴力的基础上优化一下,优化的关键是要如何快速统计出不满足要求的数的个数 ...

  6. 常州模拟赛d5t1 journalist

    分析:出题人丧心病狂卡spfa......只能用dijkstar+堆优化. 主要的难点是字典序的处理上,一个想法是在做最短路的时候处理,边松弛边记录,比个大小记录最佳答案.具体的思路大概和最短路计数差 ...

  7. 常州模拟赛d4t3 字符串划分

    题目描述 给你一串由小写字母组成的字符串,希望你把它划分成一些小段,使得每一小段字符串中的字母 都不相同,并且希望分的段数尽量少. 然后,把这些小段按字典序排序后输出,中间由一个空格分隔. 例如:字符 ...

  8. 常州模拟赛d4t2 陶陶摘苹果

    题目描述 陶陶家的院子里有一棵苹果树,每到秋天树上就会结出 n 个苹果.苹果成熟的时候,陶陶就会 跑去摘苹果. 陶陶的手不能弯 (他仅能把手伸直),当且仅当陶陶达到的高度与苹果的高度相等的时候,陶陶 ...

  9. 常州模拟赛d3t3 两只怪物心心相印

    题目背景 从前我是一位无名的旅人,旅途中我得到了某样东西:贤者之石.我因此得到悠久的时光和漂泊的生命.1897年冬天,我一时兴起舍弃了旅人的生活. 贤者之石创造出来的,是货真价实的黄金.我的名声传遍了 ...

随机推荐

  1. jenkins SVN更改密码后出现的坑爹问题

    1.前提 公司SVN账号密码和AD账号密码是绑定在一起的,为了保证代码检出总是最新,jenkins中做代码检查前总会从SVN中检出最新代码. 最近公司要求AD账户不得使用原始密码,更改密码后,jenk ...

  2. "xxadmin" user: No protocol specified 错误

    1 查看DISPLAY是否设置:env| grep DISPLAY 如未设置则,export DISPLAY=192.168.0.9:0.0 (斜体字修改为自己的服务器的ip) 2   root用户执 ...

  3. dlopen与dlsym用法

    dlopen和dlsym是用于打开动态链接库中的函数,将动态链接库中的函数或类导入到本程序中: dlopen函数: 功能:打开一个动态链接库 包含头文件: #include <dlfcn.h&g ...

  4. org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'requestMappingHandlerMapping' defined in class path resource

    spring boot web项目运行时提示如下错误 org.springframework.beans.factory.BeanCreationException: Error creating b ...

  5. springmvc+maven搭建web项目

    1.创建一个maven project 为spring1 2.进行项目的配置:默认的java 1.5 在properties中选择project facts项目进行配置,反选web之后修改java环境 ...

  6. Java习题附答案

    第一章练习题(Java入门) 1.下列哪项不是JDK所包含的内容?(选一项)C 红色代表正确答案 A.Java编程语言 B.工具及工具的API C.Java EE扩展API D.Java平台虚拟机 2 ...

  7. JS中鼠标左右键以及中键的事件

    在三维场景中有时候需要判断鼠标的事件,除了使用的click事件,只有鼠标左键有效,而右键无效.而对于onmousedown.onmouseup的时候鼠标的事件左键/右键有效.详细请看w3c上的资料. ...

  8. tp5 -- 微信公众号支付

    近来期间比较忙, 忙完之后发现最近有挺多的东西没有整理,于是乎.就将以前用到的一些小东西整理了一下. 如果对您有帮助,则是我最大的幸运. 本篇主要是说了一下整合TP5的微信公众号支付. 不过由于最近T ...

  9. vue 封装组件上传img

    var _uploadTemplate = '<div>'+ '<input type="file" name="file" v-on:cha ...

  10. 【树形dp】7.14城市

    很典型的按照边考虑贡献的题. 题目描述 小A居住的城市可以认为由n个街区组成.街区从1到n依次标号街区与街区之间由街道相连,每个街区都可以通过若干条街道到达任意一个街区,共有n-1条街道.其中标号为i ...