列置换密码

列置换密码参考教材:《现代密码学教程》P46 3.1.1过程加密过程将明文p以设定的固定分组宽度m按行写出,即每行有m个字符;若明文长度不是m的整数倍,则不足部分用双方约定的方式填充,如双方约定用空格代替空缺处字符,不妨设最后得字符矩阵[Mp]n×m按1,2…,m的某一置换σ交换列的位置次序得字符矩阵[Mp]n×m把矩阵按[Mp]n×m列的顺序依次读出得密文序列c。解密过程将...
摘要由CSDN通过智能技术生成

列置换密码

参考教材:《现代密码学教程》P46 3.1.1

过程

加密过程

  1. 将明文p以设定的固定分组宽度m按行写出,即每行有m个字符;若明文长度不是m的整数倍,则不足部分用双方约定的方式填充,如双方约定用空格代替空缺处字符,不妨设最后得字符矩阵[Mp]n×m
  2. 按1,2…,m的某一置换σ交换列的位置次序得字符矩阵[Mp]n×m
  3. 把矩阵按[Mp]n×m列的顺序依次读出得密文序列c

解密过程

  1. 将密文c以分组宽度n按列写出得到字符矩阵[Mp]n×m
  2. 按加密过程用的置换σ的逆置换σ-1交换列的位置次序得字符矩阵[Mp]n×m
  3. 把矩阵[Mp]n×m按1,2…,n行的顺序依次读出得明文p

说明

以例3.2为例
在这里插入图片描述
σ=(143)(56)即每个括号里部分轮着相对应
1→4→3→1
5→6→5
这里我是用字典表示

        for i in range(len(s)): 
            for j in range(len(s[i])-1):
                Key[int(s[i][j])]=int(s[i][j+1]) #密钥字典
                antiKey[int(s[i][j+1])]=int(s[i][j]) #反密钥字典
            Key[int(s[i][-1])]=int(s[i][0]) #解决最后一个的问题
            antiKey[int(s[i][0])]=int(s[i][-1
  • 1
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值