跪了一个下午了,才发现在循环哪里写错了WA到死。
题目意思是:
10
4 5 3 7 2 8 1 6 10 9
1 Hello Bob
1995 CERC
0
0
给出了一个长为N的序列,和需要按这序列交换k次的字符串 (如长度不足n,就补空格) .交换方式时字符串下标为i与序列中num[i]进行交换。
做法,还是根据循环节,既然它都说按照这个关系交换的,那就有个规律进过L就换回原来位置,这个L就是循环节长度,交换k次,k个L略去K%L就是其最后的结果。
k没限制大小所以直接模拟必然会超时.
/* Problem ID:poj 1026 Meaning: 将i上的字符与num[i]交换k次 Analyzing:置换群组合数学 */ #include <iostream> #include<cstdio> #include<cstdlib> #include<cstring> #include<vector> using namespace std; #define FOR(i,s,t) for(int i=(s); i<(t); i++) #define LL long long #define BUG puts("here!!!") #define STOP system("pause") #define file_r(x) freopen(x, "r", stdin) #define file_w(x) freopen(x, "w", stdout) #define maxn 205 LL gcd(LL a,LL b) {return a?gcd(b%a,a):b;} int main(){ int n,num[maxn],k,L[maxn]; char str[maxn],str1[maxn]; while(scanf("%d",&n)&&n){ FOR(i,0,n) {scanf("%d",&num[i]);num[i]-=1;} memset(L,0,sizeof(L)); FOR(i,0,n){ int j=num[i]; while(1){ L[i]++; j=num[j]; if(j==num[i]) break; } } while(scanf("%d",&k)&&k){ getchar(); gets(str); int len=strlen(str); FOR(i,len,n) str[i]=' '; str[n]='\0'; memset(str1,0,sizeof(str1)); strcpy(str1,str); FOR(i,0,n){ int l=i,r=i; FOR(j,0,k%L[i]) r=num[r]; str1[r]=str[l]; } puts(str1); } puts(""); } return 0; }