zoukankan      html  css  js  c++  java
  • python之 libnum库安装使用方法(04)

    https://www.cnblogs.com/pcat/p/7225782.html

    0x2 坑爹的pip安装

    Pypi上的libnum介绍是python3 comptaible fork for libnum - Some number theoretic functions.

    如果你使用pip安装:

    pip install libnum

    这个版本只能在py3中使用,但能在py2顺利安装,一使用就会报错,因为其strings.py的写法只适应于py3。

    # -*- coding: cp936 -*-
    import libnum
    def egcd(a, b):
        if (b == 0):
            return 1, 0, a
        else:
            x, y, q = egcd(b, a % b)  # q = GCD(a, b) = GCD(b, a%b)
            x, y = y, (x - (a // b) * y)
            return x, y, q
    
    
    def mod_inv(a, b):
        return egcd(a, b)[0] % b  # 求a模b得逆
    
    p = 8637633767257008567099653486541091171320491509433615447539162437911244175885667806398411790524083553445158113502227745206205327690939504032994699902053229
    q = 12640674973996472769176047937170883420927050821480010581593137135372473880595613737337630629752577346147039284030082593490776630572584959954205336880228469
    dp = 6500795702216834621109042351193261530650043841056252930930949663358625016881832840728066026150264693076109354874099841380454881716097778307268116910582929
    dq = 783472263673553449019532580386470672380574033551303889137911760438881683674556098098256795673512201963002175438762767516968043599582527539160811120550041
    c = 24722305403887382073567316467649080662631552905960229399079107995602154418176056335800638887527614164073530437657085079676157350205351945222989351316076486573599576041978339872265925062764318536089007310270278526159678937431903862892400747915525118983959970607934142974736675784325993445942031372107342103852
    
    invq=mod_inv(p,q)
    mp=pow(c,dp,p)
    mq=pow(c,dq,q)
    m=((mp-mq)*invq%p)*q+mq
    print(libnum.n2s(m))
  • 相关阅读:
    java的各种日志框架
    (4)一起来看下mybatis框架的缓存原理吧
    (3)一起来看下使用mybatis框架的select语句的源码执行流程吧
    Markdown基本语法
    openstack中使用linux_bridge实现vxlan网络
    python基础—第一句Python语句以及条件语句
    Java内存详解
    Java工具类练习题和答案
    面向过程和面向对象
    网页设计案例
  • 原文地址:https://www.cnblogs.com/tulater/p/13306875.html
Copyright © 2011-2022 走看看