一、思想国
1、置换的原理
通过给出一个交换序列,将原始序列进行一个交换这样得到一个新的字符或者文件。
2、分为两大部分:加密和解密
1.加密:将明文按固定长m分组,即每行m个字母,在密钥控制下按某一顺序交换列,最后按列优先的顺序依次读出(按照列依次读取),即产生了密文。
2.解密:通过序列以及总长度然后进而得到了每一段的长度,这样就能够进行分段从而得到下一步所需要的矩阵,最后矩阵按照行提取就行
3、具体实例过程
二、具体实现
0、整体思路构建
1、find(int n, int queue[], int len_queue)
发现函数,用于数字i在序列中所处的位置------>可以用在加密时候提取第i列,提取需要升序的1->7,而在解密时候就是find用于找到i对应的列数长度,还原加密时候的句子
加密时:
解密时:1、解密的时候需要进行分段,找到原来的列数就能知道该列的长度是多少,所以解密的给长度间接的提供了帮助。2、得到矩阵之后也方便进行列与列之间的转移
2、为了方便有字符矩阵(二维字符数组)到字符数组的转换,增加了字符追加函数
char_append(char resource[], char* append)
char_append(char resource[], char append)
3、字符矩阵列有长有短,所以用一个width[]专门记录每一列的长度,因为解密时需要自己分割字符数组,所以知道长度之后就能比较好的分割了
4、在加密时候需要提取每一段,然后以列展开。所以这里不妨就建立一个提取函数
5、由于解密时候矩阵按列提取的话,有点列长有的列短。所以方便起见也建立一个函数用来判断哪一个列短一些,哪一列长一些,以逻辑值返回,在使用时就只需要判断哪一个true或者哪一个是false
二、中间出现的问题
1、以整形数组为参数,期间用sizeof(a)/sizeof(int)计算a的长度,但是实际上传入的赋给了一个字符指针,所以sizeof(a)的大小就是sizeof(int)的大小,结果为1,得到结果就变成牛头不对马嘴了。
2、在函数里面最好不要返回局部变量,因为局部变量随函数的结束而销毁。(一个函数返回的本地变量或临时对象的地址。 本地变量和临时对象会被销毁时某个函数返回,因此返回的地址无效。)
三、得到的经验
1、将整个过程进行模块化编程,大大减轻了心里压力,将某一些明显的功能利用函数实现不仅使结构更清晰,而且有利于再次使用,如find(),long_or_short(),而且纠错也就更方便,所以以后要每次都去培养这样的思维。