博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
乘数加密解密
阅读量:5960 次
发布时间:2019-06-19

本文共 1783 字,大约阅读时间需要 5 分钟。

hot3.png

//功能:乘数加密 K=3 5 7 9 11 15 17 19 21 23 25

#include <stdio.h>

int str_len(char *str)//求字符串的长度
{
 int len = 0;
 while(*(str++))
  len++;
 return len;
}
int main(int argc, char *argv[])
{
 char a[26] = {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
 char b[26] = {'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
 char str[50];
 int k;
 printf("Please input the words(必须是小写可以用函数改变) :");
 gets(str);
 printf("Please input the following number[3][5][9][11][15][17][19][21][23]:");//可以求逆元的数
  scanf("%d",&k);
 int len = str_len(str);
 for(int i = 0;i<len;i++)
  for(int j = 0;j<26;j++)
  {
   if(str[i]==a[j])
    str[i] = b[(k*j)%26]//换
   else
    str[i] = str[i];//将空格等符号落下来
   }
  printf("%s\n",str);//打印
 return 0;
}

//解密

#include <stdio.h>

求字符串长度

int str_len(char *str)
{
 int len = 0;
 while(*(str++))
  len++;
 return len;
}

//求逆元

int mulny(int k)
{
 int t;
 for(int i = 0;i<26;i++)
 {
  t=k*i;
  if(t%26==1)
   return i;
 }
}

int main(int argc, char *argv[])

{
 char a[26] = {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
 char b[26] = {'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
 char str[50];
 int k;
 printf("Please input the words :");
 gets(str);
 printf("Please input the following number[3][5][9][11][15][17][19][21][23]:");//26以内有逆元的数字
 scanf("%d",&k);
 int p = mulny(k);
 int len = str_len(str);
 for(int i = 0;i<len;i++)
  for(int j = 0;j<26;j++)
  {
   if(str[i]==a[j])
    str[i] = b[(p*j)%26];
   else
    str[i] = str[i];
  }
  printf("%s\n",str);
 return 0;
}

/*

会凯撒加密的这个应该没啥大问题,但是刚刚玩,我调试还是调试了一会的,我记得昨天都调好了,今天加密找不到了,存储代码的时候没规律。哎哎,又改的幸好不费劲。也许有错的地方希望提出改正,我想进步哦!谢谢大家。

 

*/

转载于:https://my.oschina.net/u/1240964/blog/170904

你可能感兴趣的文章
Centos下基于Hadoop安装Spark(分布式)
查看>>
3D地图的定时高亮和点击事件(基于echarts)
查看>>
mysql开启binlog
查看>>
设置Eclipse编码方式
查看>>
分布式系统唯一ID生成方案汇总【转】
查看>>
并查集hdu1232
查看>>
Mysql 监视工具
查看>>
从前后端分离到GraphQL,携程如何用Node实现?\n
查看>>
Linux Namespace系列(09):利用Namespace创建一个简单可用的容器
查看>>
博客搬家了
查看>>
Python中使用ElementTree解析xml
查看>>
jquery 操作iframe、frameset
查看>>
解决vim中不能使用小键盘
查看>>
jenkins权限管理,实现不同用户组显示对应视图views中不同的jobs
查看>>
我的友情链接
查看>>
CentOS定时同步系统时间
查看>>
批量删除用户--Shell脚本
查看>>
Eclipse Java @Override 报错
查看>>
知道双字节码, 如何获取汉字 - 回复 "pinezhou" 的问题
查看>>
linux中cacti和nagios整合
查看>>