简易的16进制大数模计算器:用于密码学模运算【含资源!见页首】

简易的16进制大数模计算器:用于密码学计算

# -*- coding: utf-8 -*-

import binascii
import struct


def extendGcd(a, m):
    if a < m:
        a, m = m, a
        x1, x2, x3 = 1, 0, a
        y1, y2, y3 = 0, 1, m
        while y3 != 0:
            Q = x3 // y3
            t1, t2, t3 = x1 - Q * y1, x2 - Q * y2, x3 - Q * y3
            x1, x2, x3 = y1, y2, y3
            y1, y2, y3 = t1, t2, t3
        return x2
    else:
        x1, x2, x3 = 1, 0, a
        y1, y2, y3 = 0, 1, m
        while y3 != 0:
            Q = x3 // y3
            t1, t2, t3 = x1 - Q * y1, x2 - Q * y2, x3 - Q * y3
            x1, x2, x3 = y1, y2, y3
            y1, y2, y3 = t1, t2, t3
        return x1


def str2int(strin):
    in10t = int(strin, 16)
    return in10t


def lcm(x, y):
    m = max(x, y)
    n = min(x, y)
    while m % n:
        m, n = n, m % n
    return x * y // n


def main():
    while 1:
        print(
            "【=====Calc 2.0 ————>>> 用于大数模计算=====】".center(45), "\n!【==输入的数据需要是16进制==】\n操作有以下四种:\n  |① “+”\n  |② "
              "“-”\n  |③ “*”\n  |④ “-1” ("
              "求对象与模m的乘法逆元)\n------------------------------------------------------------------------------\n"
              "【SM2"
              "默认模数为:FFFFFFFEFFFFFFFFFFFFFFFFFFFFFFFF7203DF6B21C6052B53BBF40939D54123】\n请输入模数m(64位16进制数):(默认SM2模数按g/G)",
            end='')
        mod = input()
        if mod == "g" or "G":
            mod = str2int("FFFFFFFEFFFFFFFFFFFFFFFFFFFFFFFF7203DF6B21C6052B53BBF40939D54123")
        else:
            mod = str2int(mod)
        print("模数为:", mod)

        print("键入第一个数a:", end='')
        num_a = input()
        num_1 = str2int(num_a)

        print("键入操作:", end='')
        opration = input()

        if opration == "+":
            print("输入加数b:", end='')
            num_b = input()
            num_2 = str2int(num_b)
            sum = hex((num_1 + num_2) % mod)
            print("模加结果是:", sum)

        if opration == "-":
            print("输入减数b:", end='')
            num_b = input()
            num_2 = str2int(num_b)
            sub = hex((num_1 - num_2) % mod)
            print("模减结果是:", sub)

        if opration == "*":
            print("输入减数b:", end='')
            num_b = input()
            num_2 = str2int(num_b)
            mut = hex((num_1 * num_2) % mod)
            print("模乘结果是:", mut)

        if opration == "-1":
            divV = extendGcd(num_1, mod)
            if divV < 0:
                # print("divV_int输出的负数是:", divV)
                divv = hex((lcm(num_1, mod) + divV * num_1) // num_1)
                # print("divV * num_1:", divV * num_1)
                # print("num_1:", num_1)
                # print("数a和n的最小公倍数:", lcm(num_1, mod))
                print("模乘结果是:", divv)
            else:
                print("模乘结果是:", hex(divV))

        else:
            print("【==================已回到初始选单==============】")

        print("============================这是单次运算分隔符=================================")
        print("============================================================================")
        print("\n")


if __name__ == '__main__':
    main()

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

中二病也要吃饭啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值