hdu3746 Cyclic Nacklace KMP
CC always becomes very depressed at the end of this month, he has checked his credit card yesterday, without any surprise, there are only 99.9 yuan left. he is too distressed and thinking about how to tide over the last days. Being inspired by the entrepreneurial spirit of "HDU CakeMan", he wants to sell some little things to make money. Of course, this is not an easy task.
As Christmas is around the corner, Boys are busy in choosing christmas presents to send to their girlfriends. It is believed that chain bracelet is a good choice. However, Things are not always so simple, as is known to everyone, girl's fond of the colorful decoration to make bracelet appears vivid and lively, meanwhile they want to display their mature side as college students. after CC understands the girls demands, he intends to sell the chain bracelet called CharmBracelet. The CharmBracelet is made up with colorful pearls to show girls' lively, and the most important thing is that it must be connected by a cyclic chain which means the color of pearls are cyclic connected from the left to right. And the cyclic count must be more than one. If you connect the leftmost pearl and the rightmost pearl of such chain, you can make a CharmBracelet. Just like the pictrue below, this CharmBracelet's cycle is 9 and its cyclic count is 2:
Now CC has brought in some ordinary bracelet chains, he wants to buy minimum number of pearls to make CharmBracelets so that he can save more money. but when remaking the bracelet, he can only add color pearls to the left end and right end of the chain, that is to say, adding to the middle is forbidden.
CC is satisfied with his ideas and ask you for help.
题意:
给出一个字符串,将它补成有完整循环节的串至少需要加多少个字符。
完整循环节即至少要出现两次,整个字符串必须仅由若干个完整的循环节构成。
用KMP的失配数组的性质,可以直接求出循环节,那么字符串长度对循环节取模就是最后一个循环节的已有长度,那么循环节长度减去取模后的值就是要补的长度。
#include<stdio.h>
#include<string.h> const int maxn=1e6+;
const int maxm=1e5+; char t[maxm];
int p[maxm]; int main(){
int T;
scanf("%d",&T);
while(T--){
scanf("%s",t);
int i,j,ans=;
int m=strlen(t);
p[]=p[]=;
for(i=;i<m;i++){
j=p[i];
while(j&&t[i]!=t[j])j=p[j];
p[i+]=t[i]==t[j]?j+:;
}
if(p[m])printf("%d\n",(m-p[m]-m%(m-p[m]))%(m-p[m]));
else printf("%d\n",m);
}
return ;
}
hdu3746 Cyclic Nacklace KMP的更多相关文章
- HDU3746 Cyclic Nacklace —— KMP 最小循环节
		
题目链接:https://vjudge.net/problem/HDU-3746 Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) M ...
 - hdu-----(3746)Cyclic Nacklace(kmp)
		
Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
 - HDU3746 Cyclic Nacklace 【KMP】
		
Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
 - HDU 3746 Cyclic Nacklace(kmp next数组运用)
		
Cyclic Nacklace Problem Description CC always becomes very depressed at the end of this month, he ha ...
 - hdu 3746 Cyclic Nacklace  KMP循环节
		
Cyclic Nacklace 题意:给一个长度为Len( 3 <= Len <= 100000 )的英文串,问你在字符串后面最少添加几个字符可以使得添加后的串为周期串? Sample I ...
 - hdu3746 Cyclic Nacklace【nxt数组应用】【最小循环节】
		
Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
 - kuangbin专题十六 KMP&&扩展KMP HDU3746 Cyclic Nacklace
		
CC always becomes very depressed at the end of this month, he has checked his credit card yesterday, ...
 - HDU-3746 Cyclic Nacklace 字符串匹配 KMP算法 求最小循环节
		
题目链接:https://cn.vjudge.net/problem/HDU-3746 题意 给一串珠子,我们可以在珠子的最右端或最左端加一些珠子 问做一条包含循环珠子的项链,最少还需要多少珠子 思路 ...
 - [KMP求最小循环节][HDU3746][Cyclic Nacklace]
		
题意 给你个字符串,问在字符串末尾还要添加几个字符,使得字符串循环2次以上. 解法 无论这个串是不是循环串 i-next[i] 都能求出它的最小循环节 代码: /* 思路:kmp+字符串的最小循环节问 ...
 
随机推荐
- learning ddr mode register MR2
 - object遍历删除空值
			
export function deleteObjEmpty(search = {}) { for (let i in search) { search[i] == undef ...
 - mysql不会使用索引,导致全表扫描情况
			
不会使用索引,导致全表扫描情况 1.不要使用in操作符,这样数据库会进行全表扫描,推荐方案:在业务密集的SQL当中尽量不采用IN操作符 2.not in 使用not in也不会走索引推荐方案:用not ...
 - Unix分类学习
			
调试 shell # bash -x script.sh 设置终端背景色 setterm -background black 一.网络 1.网卡状态 mii-tool -v ethtool eth0 ...
 - Docker常用命令学习
			
sudo service docker startsudo docker run hello-worlddocker stats --helpdocker run -d -P training/web ...
 - Appium Python API
			
1.contexts contexts(self): Returns the contexts within the current session. 返回当前会话中的上下文,使用后可以识别H5页面的 ...
 - oracle概要文件profile详解
			
一.目的: Oracle系统中的profile可以用来对用户所能使用的数据库资源进行限制,使用Create Profile命令创建一个Profile,用它来实现对数据库资源的限制使用,如果把该prof ...
 - Nginx日志和http模块相关变量
			
$arg_PARAMETER #HTTP 请求中某个参数的值,如/index.php?site=www.ttlsa.com,可以用$arg_site 取得 www.ttlsa.com 这个值. $ar ...
 - jq 全选与联动的小例子
			
function initcheckbox () { $(".j-jobs-power dl dt input").click(function () { if (this.che ...
 - django面试七
			
Dango model 几种继承形式抽共享继承不能等实例化,抽象方法必须在子类中实现,Django不对其建立对应的表.class Animal(models.Model): name = models ...