第二题:只统计小写字母,如果是大写或者混合的话原理也是一样
#include
#include
int main()
{
char str[99];
int i,j,a[26]={0};
gets(str);
for(i=0;i{
for(j=0;j<26;j++)
if(str[i]==97+j)a[j]++;
}
for(j=0;j<26;j++)
if(a[j]!=0)printf("%c %d\n",97+j,a[j]);
printf("\n");
return 0;
}
第三题
解密:m=Da,b(c)=a-1(c-d)(mod26) //d是什么你没给出,只做了加密部分
#include
#include
#include
#include
int main()
{
unsigned a,b,i;
char str[99]="asdfABC";
srand(time(0));
b=rand()%26;
loop:
a=rand()%26;
if(a%2==0||a==13)goto loop;
printf("密匙为:%d,%d\n",a,b);
for(i=0;i{
if(str[i]>='a'&&str[i]<='z')
str[i]=(str[i]*a+b)%26+97;
if(str[i]>='A'&&str[i]<='Z')
str[i]=(str[i]*a+b)%26+65;
printf("%c",str[i]);
}
printf("\n");
return 0;
}