杭电1200-To and Fro(水题)

本文介绍了一种基于字符数组的蛇形加密方法,并提供了一段详细的C++实现代码。该算法通过特定规则将输入字符串转换为二维字符数组,再按列输出实现解密过程。文章还特别指出奇数行和偶数行的处理方式不同。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

//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; } }


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值