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

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

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);
        }
    }
}
相关推荐
wu_ye_m7 分钟前
学习c语言第34天 用函数每次输出+1,链式访问,int和void
c语言·学习·算法
凉、介13 分钟前
深入理解 ARMv8-A|Application Binary Interface (ABI)
c语言·笔记·学习·嵌入式·arm
2301_7890156240 分钟前
Linux基础开发工具一:软件包管理器、vim编辑器
linux·服务器·c语言·汇编·c++·编辑器·vim
玖玥拾42 分钟前
C/C++ 基础笔记(十)
c语言·c++
hanlin031 小时前
基于OpenHarmony 5.0的CAN驱动移植步骤
linux·c语言·华为·can·openharmony·t527
聆风吟º1 小时前
【C标准库】深入理解C语言 atoi 函数:字符串转换为整数
c语言·开发语言·库函数·atoi
如君愿2 小时前
考研复习 Day 48 | 密码学--第八章 数字签名与身份认证(上)
考研·密码学
三品吉他手会点灯11 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
kkeeper~11 小时前
0基础C语言积跬步之动态内存管理
c语言·开发语言
艾iYYY11 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法