置换加密解密过程

一、思想国

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、得到矩阵之后也方便进行列与列之间的转移


1、进行分段
列与列之间转移

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(),而且纠错也就更方便,所以以后要每次都去培养这样的思维。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。