题目地址: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的更多相关文章

  1. codevs1051单词接龙(栈)

    /* 看到n的范围就觉得这个不可能是DP啥的 因为这个接龙的规则十分的简单 只要前缀相同即可 所以先按字典序排一遍 这样保证符合规则的一定挨着 然后弄一个stack 每次拿栈顶元素看看待入栈的元素是否 ...

  2. [CODEVS1051]接龙游戏

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

  3. codevs1051接龙游戏

    1051 接龙游戏  

随机推荐

  1. JavaScript系列-----对象基于哈希存储(<Key,Value>之Key篇) (1)

    1.Hash表的结构 首先,允许我们花一点时间来简单介绍hash表. 1.什么是hash表 hash表是一种二维结构,管理着一对对<Key,Value>这样的键值对,Hash表的结构如下图 ...

  2. 《Github入门与实践》读书笔记 蟲咋先生的追求之旅(上)

    <Github入门与实践>作者: [日] 大塚弘记 译者:支鹏浩/刘斌   简介 本书从Git的基本知识和操作方法入手,详细介绍了GitHub的各种功能,GitHub与其他工具或服务的协作 ...

  3. Django----中间件详解

    Django中间件 在http请求 到达视图函数之前   和视图函数return之后,django会根据自己的规则在合适的时机执行中间件中相应的方法. 中间件的执行流程 1.执行完所有的request ...

  4. PHP面试随笔

    1.常见的HTTP状态码: 1xx系列:代表请求已被接受,需要继续处理 2xx系列:代表请求已成功被服务器接收.理解并接受 200:表示请求已成功,请求所希望的响应头或数据体将随此响应返回 201:表 ...

  5. Java 核心内容相关面试题【4】

    spingmvc 和 structs的区别 我们用struts2时采用的传统的配置文件的方式,并没有使用传说中的0配置. spring3 mvc可以认为已经100%零配置了(除了配置spring mv ...

  6. 基础进阶(一)之HashMap实现原理分析

    HashMap实现原理分析 1. HashMap的数据结构 数据结构中有数组和链表来实现对数据的存储,但这两者基本上是两个极端. 数组 数组存储区间是连续的,占用内存严重,故空间复杂的很大.但数组的二 ...

  7. R语言高性能编程(二)

    接着上一篇 一.减少内存使用的简单方法1.重用对象而不多占用内存 y <- x 是指新变量y指向包含X的那个内存块,只有当y被修改时才会复制到新的内存块,一般来说只要向量没有被其他对象引用,就可 ...

  8. JavaScript学习笔记(二)——字符串

    在学习廖雪峰前辈的JavaScript教程中,遇到了一些需要注意的点,因此作为学习笔记列出来,提醒自己注意! 如果大家有需要,欢迎访问前辈的博客https://www.liaoxuefeng.com/ ...

  9. Nginx+Tomcat+Redis实现持久会话

    使用开源web应用solo blog进行项目演示.前端使用Nginx作为负载均衡器,后端Tomcat连接Redis实现session存储.Redis的特点就是可以将session持久化.样才能真正实现 ...

  10. TFboy养成记

    转自:http://www.cnblogs.com/likethanlove/p/6547405.html 在tensorflow的使用中,经常会使用tf.reduce_mean,tf.reduce_ ...