UVa455 - Periodic Strings

举报
小哈里 发表于 2022/05/10 22:54:31 2022/05/10
【摘要】 //UVa455 - Periodic Strings//题目:求一个串的最小循环节。 #define A1 //直接枚举 O(N*N) 已经AC#define A2 //旧代码,WA #ifdef A1#include<stdio.h>#include<string.h>int main(){ //freope...

  
  1. //UVa455 - Periodic Strings
  2. //题目:求一个串的最小循环节。
  3. #define A1 //直接枚举 O(N*N) 已经AC
  4. #define A2 //旧代码,WA
  5. #ifdef A1
  6. #include<stdio.h>
  7. #include<string.h>
  8. int main(){
  9. //freopen("data.in","r",stdin);
  10. char s[100];
  11. int n;
  12. scanf("%d",&n);
  13. while(n--){
  14. scanf("%s",s);
  15. int len = strlen(s);
  16. for(int j, i = 1; i <= len; i++) if(len%i == 0){
  17. for(j = i; j < len; j++) if(s[j] != s[j%i]) break;
  18. if(j == len){ printf("%d\n",i); break;}
  19. }
  20. if(n)printf("\n");
  21. }
  22. return 0;
  23. }
  24. #endif
  25. #ifdef A2
  26. #include<stdio.h>
  27. #include<string.h>
  28. int main(){
  29. //freopen("data.in","r",stdin);
  30. int T;
  31. scanf("%d",&T);
  32. while(T--){
  33. char s[85];
  34. int len,is=0;
  35. scanf("%s",s);
  36. len = strlen(s);
  37. for(int i = 1; i <= len/2; i++){//i为周期,周期长小于一半的字符串长
  38. if(len%i == 0){//字符串长度为循环节整数倍
  39. is=1;//开关
  40. for(int j =1;j < len/i; j++)//字符串中的第j个对应周期的首元素是否相等
  41. for(int l = 0; l < i; l++)//字符串中的第j个对应周期的第i个元素是否相等
  42. if(s[l] != s[j*i+l]){is=0;break;}
  43. }
  44. if(is){printf("%d\n",i);break;}
  45. }
  46. if(!is)printf("%d\n\n",0);
  47. }
  48. return 0;
  49. }
  50. //测试数据:abcabcabc len=2
  51. //测试数据:acadacad len=4
  52. //测试数据:acacac len=2
  53. //测试数据:aaaaaa len=1
  54. #endif

文章来源: gwj1314.blog.csdn.net,作者:小哈里,版权归原作者所有,如需转载,请联系作者。

原文链接:gwj1314.blog.csdn.net/article/details/54744429

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。