codevs1051
题目地址:http://codevs.cn/problem/1051/
分析:
——题目难度:提高一等
1、数据结构(Data Structure):①Hash(用map或人工)②Stack(栈)
2、算法(Algorithm): DP 穷举
3、题目简述:
给出了n个按长度排序单词,假设某单词i是某单词j的前缀,i->j算一次接龙(两个同样的单词不能算接龙) 求最长龙的长度
4、算法描写叙述:
算法①:
这题我第一感觉是DP,和打导弹(拦截导弹)那题大同小异,可是n的范围伤不起 最大100000
时间复杂度:O(n^2)
空间复杂度:O(n)
非常明显不行
算法②:
事实上按照题目中这样的接龙的方式。我们非常easy就想到枚举的算法。比方有一个单词tihs,我们先枚举tih。再枚举ti,再枚举t , 枚举他们是不是在前面出现过(题目说了单词按长度排序,至于为什么倒过来而不是先t再ti再tih ,是由于这样第一次找到的一定是最长的那个。直接改动了break就能够了,推断是否出现过就用哈希表了)
这种算法明显比算法①快,但还是有压力的
时间复杂度:哈希表我用的map实现(偷懒- -) map查找和插入都是O(log n)
一共是N个单词,每一个单词要查找k次,插入1次
总时间复杂度O(n * k * log n + n * log n),
PS:咳咳,仅供參考啊 參考 參考
空间复杂度: O(n) 仅仅要有Hash就能够了 Map是动态扩展
这样看。空间上没有问题,但时间上还是非常危急,在OJ上这个算法我拿了80分,2个点接近2.4秒,非常恐怖
算法③:
这个算法有一些技巧,但也不难想到,为什么这么说呢?
事实上仅仅要你是一个玩过接龙游戏的人看这个题目的时候就会发现这个规则十分的特别,寻常的接龙游戏是后缀接前缀,而本题的规则非常特殊。前缀才是接龙
这就启示我们将全部单词按字典序排序,这样就使得前缀同样的单词被“挤”在一起了
然后我们维护一个栈,枚举全部的字符串(按字典序排好的) 假设当前的字符串能和栈顶的字符串接龙的话。那么当前字符串入栈,继续枚举下一个字符串。假设不能接龙,那么栈顶字符串弹出,当前字符串继续与弹出后的栈顶字符串比較。直到当前字符串与栈顶字符串能接成龙,然后当前字符串入栈,在这期间统计栈最多有多少个元素
5、总结
本题主要在于怎样巧妙地理解并运用题目中接龙的规则。 然后合理使用栈这一数据结构
代码:
#include <string>
#include <algorithm>
#include <iostream>
#include <stack>
using namespace std; typedef struct data{
string s;
}data; bool cmp(data x,data y)
{
int len = x.s.length() < y.s.length() ? x.s.length(): y.s.length();
for(int i = 0; i < len; i++)
{
if(x.s[i] < y.s[i])
return true;
else if(x.s[i] > y.s[i])
return false;
}
if(x.s.length() < y.s.length())
return true;
else return false;
}
data ch[100007]; int main()
{
int n;
cin>>n;
for(int i = 0; i < n; i++)
cin>>ch[i].s; sort(ch,ch+n,cmp);
stack<data> mystatck;
int max = 1;
mystatck.push(ch[0]);
data tmp;
for(int i = 1; i < n; i++)
{
tmp = mystatck.top();
if(ch[i].s.find(tmp.s,0) == 0)
{
if(tmp.s.length() != ch[i].s.length())
mystatck.push(ch[i]);
}
else
{
while( !mystatck.empty()){
tmp = mystatck.top();
if(ch[i].s.find(tmp.s,0) == 0)
break;
mystatck.pop();
}
mystatck.push(ch[i]);
}
max = max > mystatck.size() ? max : mystatck.size();
// cout<<mystatck.size()<<endl;
}
cout<<max<<endl;
return 0;
}
codevs1051的更多相关文章
- codevs1051单词接龙(栈)
/* 看到n的范围就觉得这个不可能是DP啥的 因为这个接龙的规则十分的简单 只要前缀相同即可 所以先按字典序排一遍 这样保证符合规则的一定挨着 然后弄一个stack 每次拿栈顶元素看看待入栈的元素是否 ...
- [CODEVS1051]接龙游戏
题目描述 给出了N个单词,已经按长度排好了序.如果某单词i是某单词j的前缀,i->j算一次接龙(两个相同的单词不能算接龙). 你的任务是:对于输入的单词,找出最长的龙. 输入描述 Input D ...
- codevs1051接龙游戏
1051 接龙游戏
随机推荐
- asp .net连接打开数据库初步
1 #endregion59 WebDriver
- Gitpage + hexo(3.0以上)搭建博客
大半天,一边折腾,一边查找各种文档,写出的这篇文档,不知道有没有把程序表示得足够简明,有不足之处望指明. 前提:已安装好nodeJS和git. 桌面右击进入gitbash,输入npm install ...
- tornado+WSGI+Apache
1.原理 2.安装mod_wsgi http://pan.baidu.com/s/1sjsccWH configure的时候会找对应的python脚本,默认是/usr/bin/python 生成mod ...
- FPGA跨时钟域处理方法
文章主要是基于学习后的总结. 1. 时钟域 假如设计中所有的触发器都使用一个全局网络,比如FPGA的主时钟输入,那么我们说这个设计只有一个时钟域.假如设计有两个输入时钟,如图1所示,一个时钟给接口1使 ...
- 去除HTML选择——兼容IE、FireFox(document.onselectstart,样式)
引之:http://taoistwar.iteye.com/blog/278963 今天做一个拖动效果,在网上找了个模板,作发后发现一拖动就会选择其它页面部分,需要去除这个效果, 找了个模板看了下发现 ...
- Java IO(1)基础知识——字节与字符
正所谓怕什么来什么,这是知名的“墨菲定律”.Java基础涵盖各个方面,敢说Java基础扎实的人不是刚毕业的学生,就是工作N年的程序员.工作N年的程序员甚至也不敢人人都说Java基础扎实,甚至精通,往往 ...
- 为什么我的子线程更新了 UI 没报错?借此,纠正一些Android 程序员的一个知识误区
开门见山: 这个误区是:子线程不能更新 UI ,其应该分类讨论,而不是绝对的. 半小时前,我的 XRecyclerView 群里面,一位群友私聊我,问题是: 为什么我的子线程更新了 UI 没报错? 我 ...
- 微信公众号 Cookie
微信公众号开发中,使用cookie和session来存储用户状态. 但总会出现一些空的连接,cookie为[],访问路径为"\" 拦截请求输出为header为: ;Connecti ...
- 三、Hadoop学习笔记————从MapReduce到Yarn
Yarn减轻了JobTracker的负担,对其进行了解耦
- Java开发步骤
3.编辑Java源程序 使用纯文本编辑器,比如记事本notpad.exe:EditPlus.UltraEdit等专业的纯文本编辑器. Word不是纯文本编辑器. 需求:写一个Java程序,在控制台打印 ...