当前位置:首页 » 操作系统 » 置换算法代码

置换算法代码

发布时间: 2025-04-30 13:11:03

Ⅰ DES算法,求c++代码。IP置换。 1.随机产生64位二进制数 2.根据IP置换表,将此64位二

DES算法,IP置换的功能是把输入的64位数据块按位重新组合,并把输出分为L0、R0两部分,每部分各长32位,其置换规则见下表:

58,50,42,34,26,18,10,2,60,52,44,36,28,20,12,4,
62,54,46,38,30,22,14,6,64,56,48,40,32,24,16,8,
57,49,41,33,25,17,9,1,59,51,43,35,27,19,11,3,
61,53,45,37,29,21,13,5,63,55,47,39,31,23,15,7,

即将输入的第58位换到第一位,第50位换到第2位,...,依此类推,最后一位是原来的第7位。L0、R0则是换位输出后的两部分,L0是输出的左32位,R0 是右32位,例

如:设置换前的输入值为D1D2D3......D64,则经过初始置换后的结果为:L0=D58D50...D8;R0=D57D49...D7。

其典型C代码实现如下:
定义IP置换表如上表,char类型数组,长度为64;
然后,在从0到64循环,把源数组的数据按IP置换表的内容填到目的数组,即实现了IP置换;

// initial permutation (IP)
const static char IP_Table[64] = {
58, 50, 42, 34, 26, 18, 10, 2, 60, 52, 44, 36, 28, 20, 12, 4,
62, 54, 46, 38, 30, 22, 14, 6, 64, 56, 48, 40, 32, 24, 16, 8,
57, 49, 41, 33, 25, 17, 9, 1, 59, 51, 43, 35, 27, 19, 11, 3,
61, 53, 45, 37, 29, 21, 13, 5, 63, 55, 47, 39, 31, 23, 15, 7
};

void DES_InitialPermuteData(char* src,char* dst)
{
//IP
int i=0;
for(i=0;i<64;i++)
{
dst[i] =src[IP_Table[i]-1];
}
}

Ⅱ 高分求~页面置换算法OPT算法

opt算法是1966年由Belady在理论上提出的一种算法,其算法实质是:系统预测作业今后要访问的页面,置换页是将来不被访问的页面或者在最长时间后才被访问的页面,置换该页不会造成刚置换出去又立即要把它调入的现象。
这是一种理想化的置换算法,其优点是缺页中断率最低。它要求操作系统能知道进程“将来”页面的使用情况,但这是不可能实现的,因为程序的执行是不可预测的。不过通过该算法可用来模拟实验分析或理论分析其他算法的优劣性。

热点内容
淘宝客源码采集 发布:2025-04-30 16:22:59 浏览:768
复仇之渊下载ftp 发布:2025-04-30 15:38:13 浏览:858
为什么大品牌都没有安卓导航 发布:2025-04-30 15:38:13 浏览:535
不解压查看tgz文件中 发布:2025-04-30 15:34:54 浏览:327
华为鸿蒙换回安卓系统有什么影响 发布:2025-04-30 15:00:34 浏览:701
页面访问界面升级狼 发布:2025-04-30 14:58:21 浏览:470
ue4vs编译器无法自动打开 发布:2025-04-30 14:47:23 浏览:484
python数据科学手册 发布:2025-04-30 14:41:05 浏览:592
python调用cso 发布:2025-04-30 14:40:48 浏览:109
巧妙的算法 发布:2025-04-30 14:18:12 浏览:729