C语言 简单对字母进行加密 190
简单对字母进行加密。以该字母在ascii表后面的固定顺序的某字母来替换。比如第四个字母。具体第几个可以通过参数来控制。很急C语言第一课的作业望尽量多的用简单的命令不要复杂...
简单对字母进行加密。以该字母在ascii表后面的固定顺序的某字母来替换。比如第四个字母。具体第几个可以通过参数来控制。很急
C语言第一课的作业 望尽量多的用简单的命令 不要复杂的 因为课程只教了一点点 程序冗杂一点没有关系!!急求!! 展开
C语言第一课的作业 望尽量多的用简单的命令 不要复杂的 因为课程只教了一点点 程序冗杂一点没有关系!!急求!! 展开
6个回答
展开全部
#include<stdio.h>
#include<string.h>
#include<locale>
void encodeStr(char * src, char * dest, int n)
{
for (int i = 0; i < strlen(src); i++)
{
// 如果是字母的话,
// 以该字母在ascii表后面的固定顺序的某字母来替换
if (isalpha(src[i]))
{
if (src[i] == 'z')
{
src[i] = 'a';
dest[i] = src[i] + n - 1;
}
else if (src[i] == 'Z')
{
src[i] = 'A';
dest[i] = src[i] + n - 1;
}
else
{
dest[i] = src[i] + n;
}
}
}
dest[strlen(src)] = '\0';
}
int main(void)
{
printf("请输入字符串:\n");
char src[512] = {0};
char dest[512] = {0};
scanf("%s", src);
printf("请输入n的值:\n");
int n = 0;
scanf("%d", &n);
encodeStr(src, dest, n);
printf("加密后的字符串为:%s\n", dest);
return 0;
}
运行结果:
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
void main()
{
char a[50];
int k,i;
printf("请输入源码:");
gets(a);
printf("请输入加密步长:");
scanf("%d",&k);
i = 0;
while(a[i]!='\0')
{
if(a[i]>='a' && a[i]<='z')
a[i] = (a[i]-'a'+ k)%26 + 'a';
else
{
a[i] = (a[i]-'A'+ k)%26 + 'A';
}
i++;
}
printf("%s\n",a);
}
更多追问追答
追问
非常感谢 刚才运行了一下 应该就是她要的那个!!! 可不可以把void main换成别的 我看她的书上都用 int main()
追答
#include<stdio.h>
int main()
{
char a[50];
int k,i;
printf("请输入源码:");
gets(a);
printf("请输入加密步长:");
scanf("%d",&k);
i = 0;
while(a[i]!='\0')
{
if(a[i]>='a' && a[i]<='z')
a[i] = (a[i]-'a'+ k)%26 + 'a';
else
{
a[i] = (a[i]-'A'+ k)%26 + 'A';
}
i++;
}
printf("%s\n",a);
return 0;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你定义的数据类型必须是char,而且根据你输入的字母大小写进行加密:a~z为97~122.A-Z为65-90,可以自己定义加密规则,请参考。
追问
帮我写一下 我连C语言书都没看过 是我媳妇让我帮她写作业的 没辙了!!!跪求
追答
#include
int main()
{
char a [100];
int m,n;
printf("请输入加密字符\n");
gets(a);
printf("请输入加密步长:\n");
scanf("%d",&m);
printf("请确认加密步长:\n");
scanf("%d",&n);
if (m==n)
{
printf("步长设定正确\n");
}
else
{
printf("步长不正确,退出");
return 1;
}
int i = 0;
while(a[i]!='\0')
{
if (a[i]>='a'&&a[i]<='z')
{
a[i]= (a[i]-'a'+m)%26+'a';
}
else
{
a[i] = (a[i] -'A'+m)%26+'A';
}
i++;
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询