zoukankan      html  css  js  c++  java
  • UVa455

    //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
    ",i); break;}
    		}
    		if(n)printf("
    ");
    	}
    	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
    ",i);break;}
    		}
    		if(!is)printf("%d
    
    ",0);
    	}
    	return 0;
    }
    //测试数据:abcabcabc len=2
    //测试数据:acadacad len=4
    //测试数据:acacac len=2
    //测试数据:aaaaaa len=1
    #endif 
    

  • 相关阅读:
    【1】Chrome
    Vue
    GitHub版本控制工具入门(一)
    Vue.js 组件笔记
    最全的javascriptt选择题整理
    网站如何实现 在qq中发自己链接时,便自动获取链接标题、图片和部分内容
    js 唤起APP
    密码加密MD5,Bash64
    HTTP和HTTPS的区别及HTTPS加密算法
    计算机网络七层的理解
  • 原文地址:https://www.cnblogs.com/gwj1314/p/9444954.html
Copyright © 2011-2022 走看看