杭电1200-To and Fro(水题)

//题目大意:将一个字符串按一定规则加密后发送给另一个人,然后另一个人将其解码还原

//思路:由于规则和字符数组有关,因而定义一个字符数组,将字符串按图示存进字符数组中,再按列输出即可。注意在存的时候奇数行和偶数行不一样,字符串是蛇形加密。

//AC代码:

 
 

#include<iostream> #include<cstring> using namespace std; int main() { int clo,i,j,row; char string[500]={'0'},array[30][30]; while(1) { cin>>clo; if(clo==0) break; cin>>string; row=strlen(string)/clo; i=1;j=1; while(i<=row) { if(i%2==1)//是奇数行 { if(j<i*clo) { array[i][j%clo]=string[j-1]; j++; } if(j==i*clo) { array[i][clo]=string[j-1]; j++;i++; } } else //偶数行 { if(j<i*clo) { array[i][clo+1-j%clo]=string[j-1];j++; } else { array[i][1]=string[j-1];i++;j++; } } } for(j=1;j<=clo;j++) { for(i=1;i<=row;i++) { cout<<array[i][j]; } } cout<<endl; } }


 

猜你喜欢

转载自blog.csdn.net/liangwgl/article/details/79461930