第1关:代换-置换网络
任务描述
在密码学中,代换-置换网络(或译作置换排列网络,英语:Substitution-Permutation Network,缩写作 SP-network 或 SPN)是乘积密码和分组加密的一种,美国数学家克劳德·香农在1949年为了找到利用简单的代换-置换方式进行加密的安全加密方式,发明了代换-置换网络。
本关任务:使用 c++ 实现代换-置换网络加密,对输入的明文字符串进行代换-置换加密并打印输出。
相关知识
为了完成本关任务,你需要掌握:代换-置换网络。
编程要求
根据提示,补全右侧编辑器中 Begin-End 区间的代码,对输入的明文字符串进行移位-置换加密并打印输出。具体要求如下:
从后台获取六行数据,第一第二行表示 pi_s 盒置换,第三第四行表示 pi_p 盒置换,第五行表示密钥,第六行表示明文字符串,为了方便起见,密钥行为 32 个数字,其余行均为 16 个数字,要求对输入的明文串进行代换-置换加密并打印输出。
测试说明
#include<bits/stdc++.h>
using namespace std;