小Hi和小Ho经常用Playfair密码表加密自己的代码。 密码表是按以下步骤生成的。
1. 随机选择一个只包含大写字母的单词S作为密钥。
2. 将S中的所有字母J替换为字母I。
3. 将S中的字母依次填写进一个5x5的矩阵,按照从上到下、从左到右的顺序填充格子。填充过程中略过已经在密码表中的字母。
4. 将‘A‘-‘I‘, ‘K‘-‘Z‘(除去J之外的所有大写字母)中没有出现在密码表中的大写字母按照字母表顺序填入矩阵剩余的格子中。
举个例子:单词DIJSTRA,替换字母得到DIISTRA;将DIISTRA填入矩阵得到的密码表为(注意第二个I被略过了):
举个例子:单词DIJSTRA,替换字母得到DIISTRA;将DIISTRA填入矩阵得到的密码表为(注意第二个I被略过了):
DISTR A.... ..... ..... .....
最后将剩余字母填入,得到密码表:
DISTR ABCEF GHKLM NOPQU VWXYZ
给定作为密钥的单词,你能求出密码表吗?
第1行:一行字符串,只包含大写字母,长度不超过200
共5行,每行5个字母,表示密码表。
样例输入:
HIHOCODER
样例输出:
HIOCD ERABF GKLMN PQSTU VWXYZ
代码如下:
#include<stdio.h>
#include<string.h>
int fun(char x,char map[5][5])
{
int i,j;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
{
if(x==map[i][j])
return 0;
}
}
return 1;
}
main()
{
char data[200],map[5][5],o=‘A‘;
int i,j,n,x=0;
memset(map,‘#‘,sizeof(map));
for(n=0;n<200&&data[n-1]!=‘\n‘;n++)
{
scanf("%c",&data[n]);
if(data[n]==‘J‘)
data[n]=‘I‘;
}
i=0;j=0;
while(i<5&&j<5)
{
if(fun(data[x],map)&&x<n-1)
map[i][j++]=data[x++];
else if(x<n-1)x++;
if(x>=n-1&&fun(o,map)&&o<=‘Z‘&&o!=‘J‘)
map[i][j++]=o++;
else if(x>=n-1)o++;
if(j>=5){i++;j=0;}
}
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
{
printf("%c",map[i][j]);
}
printf("\n");
}
}
原文:https://www.cnblogs.com/yunners/p/13164344.html