codevs 1051 接龙游戏
题目描述 Description

给出了N个单词,已经按长度排好了序。如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙)。

你的任务是:对于输入的单词,找出最长的龙。

输入描述 Input Description

第一行为N(1<=N<=105)。以下N行每行一个单词(由小写组成),已经按长度排序。(每个单词长度<50)

输出描述 Output Description

仅一个数,为最长的龙的长度。

样例输入 Sample Input

5

i

a

int

able

inter

样例输出 Sample Output

3

数据范围及提示 Data Size & Hint

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 接龙游戏的更多相关文章

  1. [codevs 1051]接龙游戏(栈)

    题目:http://codevs.cn/problem/1051/ 分析: 当然单词查找树是可以的,但这题有更为简便的方法.可以先按字典序排序,然后弄一个栈,如果当前字串可以接到栈顶元素的后面,那么当 ...

  2. codevs 1051 接龙游戏(栈模拟)

    传送门 Description 给出了N个单词,已经按长度排好了序.如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙). 你的任务是:对于输入的单词,找出最长的龙. I ...

  3. AC日记——接龙游戏 codevs 1051

    1051 接龙游戏  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description 给出了N个单词,已经按长度排好了序.如果 ...

  4. 接龙游戏(codevs 1051)

    1051 接龙游戏  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 给出了N个单词,已经按长度排好了序 ...

  5. codevs1051接龙游戏

    1051 接龙游戏  

  6. [CODEVS1051]接龙游戏

    题目描述 给出了N个单词,已经按长度排好了序.如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙). 你的任务是:对于输入的单词,找出最长的龙. 输入描述 Input D ...

  7. Flask开发成语接龙游戏,闲来无事手机玩玩自己写的游戏吧!

    英语单词学习应用 周五发布的文章Flask开发天气查询软件,带你掌握pipenv的使用与手机Termux下的部署发布后,看到喜欢的人比较多.本来周末打算照着扇贝/极光单词,写一个英语单词自测工具.但苦 ...

  8. codevs 1052 地鼠游戏

    1052 地鼠游戏 http://codevs.cn/problem/1052/ 题目描述 Description 王钢是一名学习成绩优异的学生,在平时的学习中,他总能利用一切时间认真高效地学习,他不 ...

  9. codevs 1033 蚯蚓的游戏问题

    Description 在一块梯形田地上,一群蚯蚓在做收集食物游戏.蚯蚓们把梯形田地上的食物堆积整理如下: a(1,1)  a(1,2)…a(1,m) a(2,1)  a(2,2)  a(2,3)…a ...

随机推荐

  1. 面试问题-使用Java线程做数学运算

    这是一个展示如何使用join()方法的例子. 问题: 使用Java多线程计算表达式1*2/(1+2)的值. 解决方案: 使用一个线程做加法运算,另一个线程做乘法运算,还有一个主线程main做除法运算. ...

  2. 【转发】NPAPI开发详解,Windows版

    NPAPI开发详解,Windows版 9 jiaofeng601, +479 9人支持,来自Meteor.猪爪.hanyuxinting更多 .是非黑白 .Yuan Xulei.hyolin.Andy ...

  3. Linux 执行partprobe命令时遇到Unable to open /dev/sr0 read-write (Read-only file system)

    在使用fdisk创建分区时,我们会使用partprobe命令可以使kernel重新读取分区信息,从而避免重启系统,但是有时候会遇到下面错误信息"Warning: Unable to open ...

  4. mysql数据校验之字符集问题

    场景:主库DB:utf8字符集备库DB:gbk字符集 需求:校验主备数据是否一致,并且修复 校验过程:设置主库连接为utf8,设置备库连接为gbk,分别进行查询,将返回的的结果集按记录逐字段比较. 显 ...

  5. 在JavaScript和C#中获得referer

    1. JavaScript /** * 获取HTTP请求的Referer * @ishost 布尔类型 Referer为空时是否返回Host(网站首页地址) */ function get_http_ ...

  6. tomcat黑/白名单设置

    vim $tomcat_home/conf/server.xml(可以单个IP或者多个ip,多个ip用|分隔,支持正则) <Context path=" reloadable=&quo ...

  7. x01.os.6: 8086 指令

    M:存储器A:累加器R:寄存器SEGR:段寄存器IMM:立即数X:标志位状态依运算或操作结果而定U:相应标志位未定义-:不影响 数据传送指令 时钟数 访问次数 字节数 对标志位影响 指令意义 MOV ...

  8. 不错的flash,动漫,小插件小集

    (来源:http://abowman.com/google-modules/) embed code <object width="220" height="166 ...

  9. Windows Azure CN 超业余性能测试

    先来说说为什么会有这篇文章吧.从朋友那里搞来个Windows Azure CN的测试帐号,在公司的时候领导的朋友有一个阿里云的服务器,平时部署小东西都往上面丢,不过那是人家的东西,还有其他的应用跑在上 ...

  10. Redhat Linux 修改主机名(HOSTNAME)

    hostname #查看当前主机的主机名hostname NEWHOSTNAME #临时修改当前主机名 修改主机名vi /etc/sysconfig/network #通过配置文件修改主机名NETWO ...