codevs 1051 接龙游戏
给出了N个单词,已经按长度排好了序。如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙)。
你的任务是:对于输入的单词,找出最长的龙。
第一行为N(1<=N<=105)。以下N行每行一个单词(由小写组成),已经按长度排序。(每个单词长度<50)
仅一个数,为最长的龙的长度。
5
i
a
int
able
inter
3
1<=N<=105
方法一:模拟栈
先将输入数据按字典序排序,然后依次枚举,栈顶是当前字符串的前缀,就入栈,否则,栈顶出栈直至当前字符串可以入栈。在此期间,随时更新接龙最大值
以样例为例:设栈为stack[],答案为ans
排序后为:a able i int inter
1、栈为空,a入栈 stack:a ans=1
2、a是able的前缀,able入栈 stack:a able ans=2
3、able不是i的前缀, able出栈 stack:a ans=2
4、a不是i的前缀,a出栈 stack: ans=2
5、栈为空,i入栈 stack:i ans=2
6、i是int的前缀,int入栈 stack:i int ans=2
7、int是inter的前缀,inter入栈 stack:i int inter ans=3
结束
截取前缀时,可以使用assign函数,头文件:cstring
格式:p.assign(s,start,len) 在s中从位置start开始,截取长尾len的字符串复制给p
附:string常用函数:http://www.cnblogs.com/wangkangluo1/archive/2011/07/22/2114118.html
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
using namespace std;
string s[],stack[];
int n,top,ans;
bool cmp(string a,string b)
{
return a<b;//按字典序排序,string可以直接调用<,>,=,与int,double一样
}
int main()
{
cin>>n;
for(int i=;i<=n;i++)
cin>>s[i];//s存原数据
sort(s+,s+n+,cmp);//按字典序排序
stack[top++]+=s[];//第一个先入栈
ans++;//至少有一个
for(int k=;k<=n;k++)//所有的top均为开区间
{
int l=stack[top-].size();//当前栈顶元素的长度,即s[k]要想入栈,要判断前缀的长度
string p;
p.assign(s[k],,l);//在s[k]中从第0位开始,截取长度为l的字符串,赋值给p
if(p==stack[top-])//因为top为开区间,所以比较的是top-1
{
if(s[k].size()==stack[top-].size()) continue;//前缀相等,总单词长度也相等,那么这两个单词相等,题目说了不能算
stack[top++]=s[k];//可以入栈
}
else
{
while(top&&stack[top-]!=p.assign(s[k],,l))//一直退到能入栈或栈为空
{
top--;
if(top)//栈为空时,top=0,不加这句会RE
l=stack[top-].size();//l转变为下一个要比较的单词的长度
}
stack[top++]=s[k];//入栈
}
ans=max(ans,top);//更新答案
}
cout<<ans;
}
方法二:http://www.cnblogs.com/IUUUUUUUskyyy/p/6193997.html
两个错误:1.退栈时,在比较的是当前栈顶元素,所以l、p需要更新。开始做的时候没有更新,一直用最初的栈顶元素比
2、ans初值为0,for循环从2开始,所以如果只有1个元素,输出0,但应该输出1
codevs 1051 接龙游戏的更多相关文章
- [codevs 1051]接龙游戏(栈)
题目:http://codevs.cn/problem/1051/ 分析: 当然单词查找树是可以的,但这题有更为简便的方法.可以先按字典序排序,然后弄一个栈,如果当前字串可以接到栈顶元素的后面,那么当 ...
- codevs 1051 接龙游戏(栈模拟)
传送门 Description 给出了N个单词,已经按长度排好了序.如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙). 你的任务是:对于输入的单词,找出最长的龙. I ...
- AC日记——接龙游戏 codevs 1051
1051 接龙游戏 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 给出了N个单词,已经按长度排好了序.如果 ...
- 接龙游戏(codevs 1051)
1051 接龙游戏 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 给出了N个单词,已经按长度排好了序 ...
- codevs1051接龙游戏
1051 接龙游戏
- [CODEVS1051]接龙游戏
题目描述 给出了N个单词,已经按长度排好了序.如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙). 你的任务是:对于输入的单词,找出最长的龙. 输入描述 Input D ...
- Flask开发成语接龙游戏,闲来无事手机玩玩自己写的游戏吧!
英语单词学习应用 周五发布的文章Flask开发天气查询软件,带你掌握pipenv的使用与手机Termux下的部署发布后,看到喜欢的人比较多.本来周末打算照着扇贝/极光单词,写一个英语单词自测工具.但苦 ...
- codevs 1052 地鼠游戏
1052 地鼠游戏 http://codevs.cn/problem/1052/ 题目描述 Description 王钢是一名学习成绩优异的学生,在平时的学习中,他总能利用一切时间认真高效地学习,他不 ...
- codevs 1033 蚯蚓的游戏问题
Description 在一块梯形田地上,一群蚯蚓在做收集食物游戏.蚯蚓们把梯形田地上的食物堆积整理如下: a(1,1) a(1,2)…a(1,m) a(2,1) a(2,2) a(2,3)…a ...
随机推荐
- MonoDevelop几个常用的快捷键
MonoDevelop几个常用的快捷键 CTRL+K 删除光标所在行的该行后面的代码 CTRL + ALT +C 注释/不注释该行 CTRL+ DOWN 像鼠标滚轮一样向下拖 CTRL + UP ...
- 十大广泛使用的Linux发行版
回到上世纪90年代,Mandrake Linux还是唯一的Linux发行版:而今天,Linux发行版的数量变得数不胜数.本文为大家整理出了十大广泛使用的Linux发行版,希望能帮助大家在选择合适的Li ...
- Asp.net禁用页面缓存的方法总结
1.在Asp页面首部<head>加入 复制代码 代码如下: Response.Buffer = True Response.ExpiresAbsolute = ...
- 谈谈yii2-gii如何自定义模板
作者:白狼 出处:http://www.manks.top/article/yii2_gii_custom_template本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位 ...
- Java中的基本数据类型
什么是基本数据类型 就是我们在编程的时候经常需要用到的数据类型,如整型,浮点型等,把这些数据类型专门拿出来特殊对待,并想象成所谓的“基本类型”. Java中有哪些基本数据类型
- Java类型擦除机制
Java泛型是JDK 5引入的一个特性,它允许我们定义类和接口的时候使用参数类型,泛型在集合框架中被广泛使用.类型擦除是泛型中最让人困惑的部分,本篇文章将阐明什么是类型擦除,以及如何使用它. 一个常见 ...
- 持续集成 .Net手册--提升开发效率和质量
参考:http://blog.csdn.net/chelsea/article/details/132525 持续集成 .Net手册 一.概念 Martin Fowler的文章:Continuous ...
- First glance in Go
Because I forgot to install the Chinese input in this OS, I have to use English input. The first pro ...
- 用自己的算法实现startsWith和endsWith功能。
String str=new String(); str="erty"; Scanner sc= new Scanner(System.in); System.out.printl ...
- 如何阻止h5body的滑动
// 禁止 document.body.style.overflow = 'hidden'; function _preventDefault(e) { e.preventDefault(); } w ...