| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1263 人关注过本帖
标题:令我百思不得其解的代码
只看楼主 加入收藏
起个名真难
Rank: 1
等 级:新手上路
帖 子:26
专家分:1
注 册:2013-3-29
结帖率:81.82%
收藏
已结贴  问题点数:10 回复次数:13 
令我百思不得其解的代码
/*********通信时经常用到加密技术,把消息加密后再传输。
编写一个用于加密消息的函数,把字符串str中的小写字母改成
“(其ASCII码加上字符串key中每个字符ASCII码的平方)除以128
所得的余数”作为ASCII码对应的字符,其它的字符不变,其中
str称为消息原文,key称为密钥。如 str="amV",key="82",则最后str="eqV"
***********/
void func(char *str,char *key)
/* 功能:用key作为密钥对字符串str进行加密处理 */
{
  int i,j;
  for(i=0;str[i]!='\0';i++)
  {if(str[i]>='a'&&str[i]<='z')
    for(j=0;key[j]!='\0';j++)
    {str[i]+=key[j];}
    str[i]=str[i]*str[i];
    str[i]=str[i]%128;
  }
}
搜索更多相关主题的帖子: 加密 加密 字符串 字符串 
2013-04-06 16:04
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:2 
我比较好奇他要怎么解码,啧啧


[fly]存在即是合理[/fly]
2013-04-06 16:06
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:2 
呵呵  这密加的...

三十年河东,三十年河西,莫欺少年穷!
2013-04-06 17:06
尹金魁2031
Rank: 3Rank: 3
来 自:河南省南阳市
等 级:论坛游侠
帖 子:156
专家分:162
注 册:2012-12-29
收藏
得分:2 
我的疑问是字符中的数字与处理后的小写字母,如何辨认,这不是二意了吗?这是计算机最忌讳的呀!
2013-04-06 18:26
yctchxf
Rank: 6Rank: 6
来 自:盐城
等 级:侠之大者
威 望:2
帖 子:176
专家分:454
注 册:2012-4-10
收藏
得分:2 
回复 4楼 尹金魁2031
数字也当做字符处理啊,所有的类型都定义成char 类型啊。
我觉得一楼的问题有意思……
2013-04-06 18:37
yctchxf
Rank: 6Rank: 6
来 自:盐城
等 级:侠之大者
威 望:2
帖 子:176
专家分:454
注 册:2012-4-10
收藏
得分:0 
以下是引用azzbcc在2013-4-6 16:06:17的发言:

我比较好奇他要怎么解码,啧啧

有意思……
2013-04-06 18:37
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:2 
,把字符串str中的小写字母改成
 “(其ASCII码加上字符串key中每个字符ASCII码的平方)除以128
 所得的余数”作为ASCII码对应的字符,其它的字符不变,
这个不就是要求么?按照这个要求进行计算的嘛

Maybe
2013-04-06 19:40
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:2 
以下是引用起个名真难在2013-4-6 16:04:03的发言:

/*********通信时经常用到加密技术,把消息加密后再传输。
编写一个用于加密消息的函数,把字符串str中的小写字母改成
“(其ASCII码加上字符串key中每个字符ASCII码的平方)除以128
所得的余数”作为ASCII码对应的字符,其它的字符不变,其中
str称为消息原文,key称为密钥。如 str="amV",key="82",则最后str="eqV"
***********/
void func(char *str,char *key)
/* 功能:用key作为密钥对字符串str进行加密处理 */
{
  int i,j;
  for(i=0;str!='\0';i++)
  {if(str>='a'&&str<='z')
    for(j=0;key[j]!='\0';j++)
    {str+=key[j];}
    str=str*str;
    str=str%128;
  }
}

不明白你没看懂什么,这不是挺好懂的?

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-04-07 12:49
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
以下是引用azzbcc在2013-4-6 16:06:17的发言:

我比较好奇他要怎么解码,啧啧

反着解码咯,这个过程是可逆的

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-04-07 12:50
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
以下是引用peach5460在2013-4-7 12:50:21的发言:


反着解码咯,这个过程是可逆的


觉得不可逆、、、

程序代码:
#include <stdio.h>
int main()
{
    int i, j, a[128] = {0};
    for (i = 'a';i <= 'z';++i)
    {
        j = i * i % 128;
        if (a[j])
        {
            printf("i = %d, j = %d\n", i, j);
        }
        a[j] = 1;
    }
    return 0;
}


[fly]存在即是合理[/fly]
2013-04-07 13:44
快速回复:令我百思不得其解的代码
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013340 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved