C语言编程:密码解密

有一行英文密码,现知道加密的方法如下:
(1)密文的第一个字母与原文相同;
(2)从第二个字母开始,每一个字母的密文的ACSII码等于(上一个字母密文的ACSII码-32)+(原文ACSII-32)的和再与96取模(即取余数)最后加上32。
要求编写解密程序,由键盘输入一行密文(最多不超过10000个字母),输出原文。

当输入一行密文:W<(tXG5z&m\K/
程序正确就输出:Welldone,good

悬赏分:10 | 解决时间:2010-11-27 19:31
//----------------------------------------------------------------------
最佳答案:
编好了,下载地址:http://www.163disk.com/fileview_148907.html

先以前两个字母分析来加密的过程:
已知原文:"We" 87 (101)
应得密文:"W<" (87) 60

密文第一个字母的ASCII码 87,是和原文 87 相同的,不用计算。
密文第二个字母的ASCII码 60,要用 87 和 101 进行计算,过程如下:
  101-32=69、87-32=55; 55+69=124; 124%96=28; 28+32=60。

后面再添一个字母,第三个字母的加密过程如下:
已知原文:"Wel" 87 101 (108)
应得密文:"W<(" 87 (60) 40
密文第三个字母的ASCII码 40,要用 60 和 108 进行计算,过程如下:
  108-32=76、60-32=28; 28+76=104; 104%96=8; 8+32=40。
===============================
按照上述的过程,进行相反的运算步骤,即可分析出解密的方法。

已知密文:"W<" 87 60
应得原文:"We" 87 101
  60-32=28; 28+96=124; 124-(87-32)=124-55=69; 69+32=101

已知密文:"W<(" 87 60 40
应得原文:"Wel" 87 101 108
  40-32=8; 8+96=104; 104-(60-32)=76; 76+32=108

分析上面两个解密的计算过程,可以得到简化的解密算法:
  60+128-87=101
  40+128-60=108
即用当前密文的 ASCII 码加上 128,再减去上一个密文的 ASCII 码。
这个简化算法里面,都包括了加上 96 的步骤。但是当初加密以 96 取模的时候,减 96 的步骤有可能是不出现的,故此加 96 的步骤也应该是可选的。因此,当结果超过了 127,成为非常规字符的 ASCII 码的时候,就减去 96。
//----------------------------------------------------------------------
下列程序已通过调试,结果正确。

#include <stdio.h>
void main(void)
{
    unsigned char i = 1, temp1[200], temp2[200];
    printf("\n\n\n Please Input mimi_wenzi: ");
    scanf("%s", temp1);
    temp2[0] = temp1[0];
    while(temp1[i] != '\0') {
      temp2[i] = temp1[i] + 128 - temp1[i - 1];   //加上128,减去前一密码
      if (temp2[i++] >= 128) temp2[i - 1] -= 96; //大于127,减去96
    }
    temp2[i] = temp1[i];
    printf("\n\n mimi_wenzi: %s\n", temp1);
    printf("\n\n yuan_wenzi: %s\n", temp2);
    getch();
}

程序经过编译,运行的画面如下:

C语言编程:密码解密 - 非著名博主 - 电子信息角落


//----------------------------------------------------------------------
回答者: 做而论道 - 十四级   2010-11-20 23:42
提问者对于答案的评价:谢谢了!
原题网址:http://zhidao.baidu.com/question/199179878.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
某同学在宿舍公用计算机上面使用文本文件来记录每天的心情故事,但是宿舍公用计算机不能设置密码,同学担心自己的日记被偷看,特委托你来完成如下加密序: 该序是一个可加密数据的日记记录工具,具有如下功能要求: 1. 运行系统后,系统给出三个选项:1)新增日记;2)阅读日记;3)退出系统 2. 选择功能1)后,系统提示用户输入日记文件名称和路径,并创建文本文件;同时,用户输入两个字符a和b,作为密钥;创建文件后,用户开始输入日记内容,日记内容为文本形式,将日记内容加密,然后将加密后的内容写入文件中; 3. 选择功能2)后,系统提示用户输入要打开的日记文件的路径和名称,打开文件后,读取文件中的密文解密后显示出来; 4. 加密算法推荐大家采用简单的文本加密算法来实现,算法思想如下,从明文读入一个字符(英文),使用密钥a与该字符做异或操作,将结果作为密文保存下来,再读入第二个字符,使用密钥b与该字符做异或操作,同样保存结果,以此类推加密全文;解密可将密文作为输入完成整个加密过,返回就是明文。如果同学们有兴趣加密中文,那么可将中文的高八位使用密钥a加密,低八位使用密钥b加密,完成加密过。 这个加密算法需要使用C语言的位运算运算符,包括:& 按位与、| 按位或、^ 按位异或、~ 取反、<> 右移。 那么本算法中的异或可用如下方法完成,c为明文中取得的一个字符,该字符加密(解密)指令如下: c = plaintext[i]; //i+1是奇数使用密钥a,是偶数采用密钥b cipher[i] = c ^ a; 那么在cipher[i]中保存的就是c的密文

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值