keyexpansionforlongest.hpp

来自「是密码学加减密中中的重要算法」· HPP 代码 · 共 48 行

HPP
48
字号
#include <iostream>
#include "Sbox.hpp"

const int Nk = 8 ;
const int Nr = 14 ;

template <typename T> // for Nk > 6
void KeyExpansionForLonger (T key[4][Nk], T word[4][Nb * (Nr + 1)])
{
	int i = 0, j = 0 ; //循环变量

	for (j = 0; j < Nk; ++j)
	{
		for (i = 0; i < 4; ++i)
		{
			word[i][j] = key[i][j] ;
		}
	}

	for (j = Nk; j < Nb * (Nr + 1); ++j)
	{
		if (j % Nk == 0)
		{
			word[0][j] = word[0][j - Nk] ^ Sbox[word[1][j - 1]] ^ Rc[j/Nk] ;
		
			for (i = 1; j < 4; ++i)
			{
				word[i][j] = word[i][j - Nk] ^ Sbox[word[(i + 1) % 4][j - 1]] ;
			}
		}

		else if (j % Nk == 4)
		{
			for (i = 0; i < 4; ++i)
			{
				word[i][j] = word[i][j - Nk] ^ Sbox[word[i][j - 1]] ;
			}
		}

		else
		{
			for (i = 0; i < 4; ++i)
			{
				word[i][j] = word[i][j - Nk] ^ word[i][j - 1] ;
			}
		}
	}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?