首页 > 其他 > 详细

hihoCoder #1361 : Playfair密码表

时间:2020-06-19 18:19:34      阅读:87      评论:0      收藏:0      [点我收藏+]
时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描述

小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");
  }
}

  

hihoCoder #1361 : Playfair密码表

原文:https://www.cnblogs.com/yunners/p/13164344.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!