密码学:古典密码.代替密码.仿射密码加密与解密 (广义欧几里得除法)

乘法密码和加法密码结合构成仿射密码,放射密码函数为

f(ai)=bi=aj (i,j为下角标)

j=i*k1+k0 mod n 只对大写英文加密n为26

其中:要求 (k1,n)=1, 0<=k0<n,且不允许同时有k1=1和k0=0

代码解释:

在输入时密文为字符串,通过ASCII码进行加减A对应的ASCII码把英文字母对应为0~25

在找k1时用广义欧几里得除法得到1~25之内与26互素的数字放在p数组里面,用于密钥k1的选择

代码:

cpp 复制代码
#include <stdio.h>
#include <string.h>
int Findp(int p[],int n)
{
    int top=0,flag=1;
    if (n%2)
        flag=0;     //如果n为偶数,偶数必然不和n互素
    {
        for (int i=1;i<n;)//利用广义欧几里得除法找1~n之内与n互素的数
        {
            int j1=n,j0=i,r=i;
            while(r!=0)
            {
               do{
                    j1-=j0;
                    r=j1;
                }while(r>=j0);
                j1=j0;
                j0=r;
            }
            if(j1==1)
                p[top++]=i;
            if(!flag)
                i+=2;
            else
                i++;
        }
    }
    return top;
}

int main()
{
    char M[9999],C[9999];
    printf("请输入明文字符(大写英文字母,回车结束)\n");
    fgets(M,9999,stdin);
    int k1,k0,n=26;
    printf("请输入密钥k1 k0(中间空格分隔,k1=1和K0=0不能同时),");
    int p[26];
    int num=Findp(p,n);
    printf("k1可取值为");
    for (int i=0;i<num;i++)
        printf("%d ",p[i]);
    printf("\n");
    scanf("%d%d",&k1,&k0);
    printf("密文\n");
    int end=strlen(M),top=0;
    for (int i=0;i<end-1;i++)
    {
        if(M[i]==' ')
            C[i]=' ';
        else
            C[i]=((M[i]-65)*k1+k0)%n+65;
    }
    for (int i=0;i<end-1;i++)
    {
            printf("%c",C[i]);
    }
    printf("\n解密\n");
    for (int i=0;i<end-1;i++)
    {
        if (C[i]==' ')
            printf("%c",C[i]);
        else
        {
            int m=(C[i]-65-k0);//不能用char类型!!!!m超过100多变为负数
            //while(-25%25)不执行 所以不能小于0
            while(m%k1 || m<0) //需要先加26 什么时候模K1为0停止
                m+=26;
        //因为选K1时互素,所以这里即使后面也有模K1为0的 除k1后再mod26是一样的结果
            printf("%c",m/k1+65);
        }
    }
}
相关推荐
嵌入式科普13 分钟前
十三、从0开始卷出一个新项目之瑞萨RZN2L串口DMA接收不定长
c语言·stm32·瑞萨·e2studio·rzn2l
小林熬夜学编程2 小时前
【Linux网络编程】第十四弹---构建功能丰富的HTTP服务器:从状态码处理到服务函数扩展
linux·运维·服务器·c语言·网络·c++·http
Jackey_Song_Odd2 小时前
C语言 单向链表反转问题
c语言·数据结构·算法·链表
A懿轩A3 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
半盏茶香3 小时前
在21世纪的我用C语言探寻世界本质 ——编译和链接(编译环境和运行环境)
c语言·开发语言·c++·算法
字节高级特工4 小时前
【C++】深入剖析默认成员函数3:拷贝构造函数
c语言·c++
计算机学长大白5 小时前
C中设计不允许继承的类的实现方法是什么?
c语言·开发语言
XH华11 小时前
初识C语言之二维数组(下)
c语言·算法
Uu_05kkq14 小时前
【C语言1】C语言常见概念(总结复习篇)——库函数、ASCII码、转义字符
c语言·数据结构·算法
嵌入式科普16 小时前
十一、从0开始卷出一个新项目之瑞萨RA6M5串口DTC接收不定长
c语言·stm32·cubeide·e2studio·ra6m5·dma接收不定长