UVa455 - Periodic Strings

//UVa455 - Periodic Strings
//题目:求一个串的最小循环节。

#define A1 //直接枚举 O(N*N) 已经AC
#define A2 //旧代码,WA

#ifdef A1
#include<stdio.h>
#include<string.h>
int main(){
	//freopen("data.in","r",stdin);
	char s[100];
	int n;
	scanf("%d",&n);
	while(n--){
		scanf("%s",s);
		int len = strlen(s);
		for(int j, i = 1; i <= len; i++) if(len%i == 0){
			for(j = i; j < len; j++) if(s[j] != s[j%i]) break;
			if(j == len){ printf("%d\n",i); break;}
		}
		if(n)printf("\n");
	}
	return 0;
}
#endif 

#ifdef A2
#include<stdio.h>
#include<string.h>
int main(){
	//freopen("data.in","r",stdin);
	int T;
	scanf("%d",&T);
	while(T--){
		char s[85];
		int len,is=0;
		scanf("%s",s);
		len = strlen(s);
		for(int i = 1; i <= len/2; i++){//i为周期,周期长小于一半的字符串长
			if(len%i == 0){//字符串长度为循环节整数倍
				is=1;//开关
				for(int j =1;j < len/i; j++)//字符串中的第j个对应周期的首元素是否相等
					for(int l = 0; l < i; l++)//字符串中的第j个对应周期的第i个元素是否相等
						if(s[l] != s[j*i+l]){is=0;break;}
			}
			if(is){printf("%d\n",i);break;}
		}
		if(!is)printf("%d\n\n",0);
	}
	return 0;
}
//测试数据:abcabcabc len=2
//测试数据:acadacad len=4
//测试数据:acacac len=2
//测试数据:aaaaaa len=1
#endif 

转载于:https://www.cnblogs.com/gwj1314/p/9444954.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值