博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj2251[2010Beijing Wc]外星联络*
阅读量:6690 次
发布时间:2019-06-25

本文共 862 字,大约阅读时间需要 2 分钟。

题意:

找一个01串中出现次数大于1的字串。01串长度≤3000

题解:

有个结论:一个串的所有后缀的所有前缀对应了这个串的字串。所以将这个串的所有后缀插入trie,累计经过trie上每个节点的经过次数,找到大于1的输出即可。

代码:

1 #include 
2 #include
3 #include
4 #define inc(i,j,k) for(int i=j;i<=k;i++) 5 #define maxn 3010 6 using namespace std; 7 8 int n,ch[maxn*maxn][2],sm[maxn*maxn],tot; char s[maxn]; 9 void insert(int x){10 int y=0;11 inc(j,x,n){12 if(!ch[y][s[j]-'0'])tot++,ch[y][s[j]-'0']=tot,y=tot;else y=ch[y][s[j]-'0']; sm[y]++;13 }14 }15 void print(int x){16 if(sm[x]>1)printf("%d\n",sm[x]);17 if(ch[x][0])print(ch[x][0]); if(ch[x][1])print(ch[x][1]);18 }19 int main(){20 scanf("%d",&n); scanf("%s",s+1); inc(i,1,n)insert(i);21 if(ch[0][0])print(ch[0][0]); if(ch[0][1])print(ch[0][1]); return 0;22 }

 

20160813

转载于:https://www.cnblogs.com/YuanZiming/p/5777983.html

你可能感兴趣的文章
抢滩登陆游戏android源码
查看>>
HAProxy负载均衡实验
查看>>
如何通过组策略配置proxy.pac
查看>>
设置ssh无密码登录
查看>>
webpack优化——定义“生产”环境
查看>>
我的友情链接
查看>>
OpenStack各服务所用端口号总结
查看>>
多线程并发下载图片NSThread
查看>>
Big Faceless Java Pdf报表生成器控件介绍
查看>>
hadoop kill mapreduce job
查看>>
XPE常见问题整理
查看>>
Vim编辑器详解
查看>>
sql 查询几个工作日之后的日期
查看>>
zeromq的使用:例子分析
查看>>
ubuntu16.04的启动栏更改和窗口特效关闭
查看>>
我的友情链接
查看>>
java --log4j
查看>>
Nginx之server指令
查看>>
用普通计算机假设基于liunx系统的NAS部署FineReport决策系统
查看>>
shell日常脚本
查看>>