2015寒假集训周赛第一场 A题
2015-01-24 15:38
274 查看
Description
Given two strings a and b we define a*b to be their concatenation. For example, if a = "abc" and b = "def" then a*b = "abcdef". If we think of concatenation as multiplication, exponentiation by a non-negative integer is defined in the normal way: a^0 = "" (the
empty string) and a^(n+1) = a*(a^n).
Input
Each test case is a line of input representing s, a string of printable characters. The length of s will be at least 1 and will not exceed 1 million characters. A line containing a period follows the last test case.
Output
For each s you should print the largest n such that s = a^n for some string a.
Sample Input
abcd
aaaa
ababab
.
Sample Output
1
4
3
Hint
This problem has huge input, use scanf instead of cin to avoid time limit exceed.
#include <stdio.h>
#include <string.h>
#include <algorithm>
char a[55555556];
int main()
{
int i,j,len;
while(~scanf("%s",a),a[0]!='.')
{
int flag;
len=strlen(a);
for(i=1; i<=len; i++)
{
flag=1;
if(len%i==0)
{
for(j=i; j<len; j++)
{
if(a[j]!=a[j%i])
{
flag=0;
break;
}
}
if(flag==1)
{
break;
}
}
}
printf("%d\n",len/i);
}
return 0;
}
Given two strings a and b we define a*b to be their concatenation. For example, if a = "abc" and b = "def" then a*b = "abcdef". If we think of concatenation as multiplication, exponentiation by a non-negative integer is defined in the normal way: a^0 = "" (the
empty string) and a^(n+1) = a*(a^n).
Input
Each test case is a line of input representing s, a string of printable characters. The length of s will be at least 1 and will not exceed 1 million characters. A line containing a period follows the last test case.
Output
For each s you should print the largest n such that s = a^n for some string a.
Sample Input
abcd
aaaa
ababab
.
Sample Output
1
4
3
Hint
This problem has huge input, use scanf instead of cin to avoid time limit exceed.
#include <stdio.h>
#include <string.h>
#include <algorithm>
char a[55555556];
int main()
{
int i,j,len;
while(~scanf("%s",a),a[0]!='.')
{
int flag;
len=strlen(a);
for(i=1; i<=len; i++)
{
flag=1;
if(len%i==0)
{
for(j=i; j<len; j++)
{
if(a[j]!=a[j%i])
{
flag=0;
break;
}
}
if(flag==1)
{
break;
}
}
}
printf("%d\n",len/i);
}
return 0;
}
相关文章推荐
- 2015寒假集训周赛第一场 F 题
- SDUT_2015寒假集训_周赛第二场_E-I hate it(HDUOJ-1754)
- SDUT_2015寒假集训_结构体练习_F-商人的诀窍
- SDUT_2015寒假集训_BFS&DFS_A-数据结构实验图论一:基于邻接矩阵的广度优先搜索遍历
- 2015西电暑期集训第一场(锘爷系列)
- SDUT_2015寒假集训_结构体练习_G-最终排名
- SDUT_2015寒假集训_动规递推_A-蟠桃记
- SDUT_2015寒假集训_结构体练习_H-顺序建立链表
- SDUT_2015寒假集训_动规递推_B-超级楼梯
- SDUT_2015寒假集训_BFS&DFS_J-Catch That Cow
- SDUT_2015寒假集训_结构体练习_I-单链表中重复元素的删除
- SDUT_2015寒假集训_动规递推_C-彼岸
- SDUT_2015寒假集训_背包_A-小P的故事——神奇的Dota
- SDUT_2015寒假集训_结构体练习_J-逆序建立链表
- SDUT_2015寒假集训_图的基本存储结构_B-图的基本存储的基本方式二
- SDUT_2015寒假集训_最短路_A-最短路(Floyd)
- SDUT2015暑假集训14级周赛4
- 2015暑假ACM集训结训赛(第一场)(SDUTOJ)
- SDUT_2015寒假集训_结构体练习_A-Milk
- SDUT_2015寒假集训_结构体练习_B-选夫婿1