博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 1026 Cipher
阅读量:5093 次
发布时间:2019-06-13

本文共 948 字,大约阅读时间需要 3 分钟。

题目:

题意:给你n个数字,然后给你一个字符串,按照n个数字的指示,将字符串的字母重新排序

 

10(10个数字)4 5 3 7 2 8 1 6 10 91 Hello Bob  (1表示重排一次,空格后面就是要排的字符串)1995 CERC  (1995表示重排1995次)
BolHeol  bC RCE
 

 

例如:      4  5  3  7  2  8  1   6  10  9

                 H  e  l   l   o      B  o   b       (不够的补空格)

得到:      B  o  l   H  e  o  l             b

 

分析:

key:

4 5 3 7 2 8 1 6 10 9(转换为数组的下标为:3 5 2 6 1 7 0 6 9 8)
消息长度也为10,下标为
0 1 2 3 4 5 6 7 8 9
其实就是消息的下标按照key来置换,当经过若干次交换之后又会回到原来的位置,姑且称这个交换的次数为循环长度loopLen
例如:0->3->6->0,那么0号位置的消息字符的循环长度loopLen[0] = 3
1->4->1,那么1号位置的消息字符的循环长度loopLen[1] = 2
 
这样,我们算出每个位置的循环长度,在需要进行k次加密的时候,只需要交换该位置i上的字符k%loopLen[i]次就可以得到最终该位置上应该有的字符。
 
代码:
#include
#include
using namespace std;int main(){ int path[200][200];//保存路径 int keyarr[200];//加密数字 int period[200];//保存周期 int N;//加密包含多少个秘钥 int k;//加密多少次 char src[500],ans[500];//需要加密的源字符串 for (scanf("%d",&N);N;scanf("%d",&N)){ int key; int i,j; memset(period,0,sizeof(int)*200); for(i=0;i

转载于:https://www.cnblogs.com/snake-hand/p/3165594.html

你可能感兴趣的文章
python学习笔记__Python的安装
查看>>
iOS设置拍照retake和use按钮为中文简体
查看>>
以下内容为Stackoverflow上整理以作纪录
查看>>
工业机器人常用语言---val语言介绍
查看>>
python3的包(package)在centos中的安装地址
查看>>
(3)Deep Learning之神经网络和反向传播算法
查看>>
Java Spring boot 企业微信点餐系统
查看>>
保持长宽比 对背景图像进行修改android:scaleType="fitXY"
查看>>
python-上传下载文件
查看>>
【转】如何解决:Android中 Error generating final archive: Debug Certificate expired on 10/09/18 16:30 的错误...
查看>>
HttpClient短信接口
查看>>
echo print printf() sprintf()区别
查看>>
https阿里云证书购买与apache环境配置
查看>>
21个js 技巧收藏
查看>>
PictureBox滚动条、鼠标中轴滚动
查看>>
Codeforces 475C Kamal-ol-molk's Painting 模拟
查看>>
G-Sensor 校准标准
查看>>
338. Counting Bits
查看>>
ArcGIS API For JS实现动态点扩散
查看>>
ios 自定义按钮
查看>>