Codeforces A ACM (ACronym Maker) (dp)
http://codeforces.com/gym/100650
概要:给出一个缩写,和一些单词,从单词中按顺序选一些字母作为缩写,问方案数。
限制:某些单词要忽略,每个单词至少要选一个字母。
dp[i][j]表示到第i个单词的时候已经选了j个字母的方案数。
很明显,当前字符ch是第j个字符的时候,第j-1个字母只能在上一个单词或者这个单词中ch之前出现,所以有dp[i][j] += dp[i][j-1] + dp[i-1][j-1]。
边界条件为dp[i][0] = 1。由于i只由i-1和自身决定因此可用滚动数组优化。
#include<bits/stdc++.h>
using namespace std; int n;
const int maxn = ;
char str[maxn];
char tar[maxn];
char word[maxn]; int sscan_line(char *s,char *&s0)
{
if(!*s0) return ;
int i = , j = ;
while(s0[i] == ' ') i++;
for(j = ;s0[i] && s0[i] != ' '; i++){
s[j++] = s0[i];
}
s[j] = '\0'; s0+=i;
return j;
} int main()
{
//freopen("in.txt","r",stdin);
while(~scanf("%d",&n)&&n){
set<string> ig;
while(n--){
scanf("%s",str);
ig.insert(str);
}
scanf("\n");
while(gets(str) && strcmp(str,"LAST CASE") != ){
//stringstream sin.(str)
char *p = str;
int tlen = sscan_line(tar,p);
int dp[maxn]={} ; dp[] = ;
for(int i = ; tar[i]; i++){
tar[i] += 'a'-'A';
}
while(sscan_line(word,p)){
if(ig.count(word) != ) continue;
int ndp[maxn]={};
for(int i = ; word[i]; i++)
for(int j = tlen-; ~j; j--)
if(word[i] == tar[j])
ndp[j+] += dp[j]+ndp[j];
copy(ndp,ndp+maxn,dp);
}
for(int i = ; i < tlen; i++){
tar[i] -= 'a'-'A';
}
int ans = dp[tlen];
if(ans) printf("%s can be formed in %d ways\n",tar,ans);
else printf("%s is not a valid abbreviation\n",tar);
}
}
return ;
}
Codeforces A ACM (ACronym Maker) (dp)的更多相关文章
- CodeForces - 710E Generate a String (dp)
题意:构造一个由a组成的串,如果插入或删除一个a,花费时间x,如果使当前串长度加倍,花费时间y,问要构造一个长度为n的串,最少花费多长时间. 分析:dp[i]---构造长度为i的串需要花费的最短时间. ...
- Educational Codeforces Round 51 D. Bicolorings(dp)
https://codeforces.com/contest/1051/problem/D 题意 一个2*n的矩阵,你可以用黑白格子去填充他,求联通块数目等于k的方案数,答案%998244353. 思 ...
- Codeforces 536D - Tavas in Kansas(dp)
Codeforces 题目传送门 & 洛谷题目传送门 其实这题本该 2019 年 12 月就 AC 的(详情请见 ycx 发此题题解的时间),然鹅鸽到了现在-- 首先以 \(s,t\) 分别为 ...
- Codeforces 295D - Greg and Caves(dp)
题意: 给出一个 \(n \times m\) 的矩阵,需对其进行黑白染色,使得以下条件成立: 存在区间 \([l,r]\)(\(1\leq l\leq r\leq n\)),使得第 \(l,l+1, ...
- Codeforces 467C George and Job(DP)
题目 Source http://codeforces.com/contest/467/problem/C Description The new ITone 6 has been released ...
- codeforces 813 D. Two Melodies(dp)
题目链接:http://codeforces.com/contest/813/problem/D 题意:求两个不相交的子集长度之和最大是多少,能放入同一子集的条件是首先顺序不能变,然后每一个相邻的要么 ...
- codeforces 762 D. Maximum path(dp)
题目链接:http://codeforces.com/problemset/problem/762/D 题意:给出一个3*n的矩阵然后问从左上角到右下角最大权值是多少,而且每一个点可以走上下左右,但是 ...
- CodeForces - 446A DZY Loves Sequences(dp)
题意:给定一个序列a,求最长的连续子序列b的长度,在至多修改b内一个数字(可修改为任何数字)的条件下,使得b严格递增. 分析: 1.因为至多修改一个数字,假设修改a[i], 2.若能使a[i] < ...
- Codeforces 559E - Gerald and Path(dp)
题面传送门 真·难度 *3000 的 D1E hb 跟我们说"做不出来不太应该". 首先我们将所有线段按 \(a_i\) 从小到大排序,一个很显然的想法是 \(dp_{i,j,d} ...
随机推荐
- HDOJ-2037
今年暑假不AC Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- python 之 exec命令
参数1:字符串形式的命令 参数2:全局作用域(字典形式),如果不指定默认使用globals() 参数3:局部作用域(字典形式),如果不指定默认使用locals() g= { 'x':1, 'y':2 ...
- git 回退到服务器版本操作
git fetch git reset orgin master --hard git pull
- Qt-MVC图形视图框架初识
使用QPushButton.QLabel.QCheckBox等构成GUI的控件或自定义图形时,开发应用程序会变得很简单.但是如果想在GUI中使用数十个或者数百个图形对象,向用户完美展示控制场景,则会受 ...
- 一步步完成“迷你版” 的ASP.NET Core框架
一 前言 Artech 分享了 200行代码,7个对象--让你了解ASP.NET Core框架的本质 . 用一个极简的模拟框架阐述了ASP.NET Core框架最为核心的部分. 这里一步步来完成这个迷 ...
- Perfect项目快速上手
1.在您从Swift.org(英文版)完成Swift 4.0 toolchain工具集安装之后,请打开一个命令行终端并输入命令 swift --version Apple Swift version ...
- 2014-5-10 NOIP模拟赛 by coolyangzc
Problem 1 机器人(robot.cpp/c/pas) [题目描述] 早苗入手了最新的Gundam模型.最新款自然有着与以往不同的功能,那就是它能够自动行走,厉害吧. 早苗的新模型可以按照输入的 ...
- [Xcode 实际操作]一、博主领进门-(10)Xcode右侧界面介绍
目录:[Swift]Xcode实际操作 本文将演示Xcode右侧界面介绍. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] 右上角第三个[辅助编辑器]按钮,将代码切 ...
- zookeeper 搭建
zookeeper 版本为zookeeper 3.4.8 操作系统为ubuntu 12.04 64位 zookeeper 单机搭建 解压zookeeper 包 .tar.gz -C /root/sof ...
- JSP技术概念