首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ZeroDivisionError:逆向不存在

ZeroDivisionError:逆向不存在
EN

Stack Overflow用户
提问于 2013-11-10 04:21:08
回答 1查看 1.1K关注 0票数 0

问题是2在整数模式环(6)中是不可逆的。我想将结果拆分为2作为普通整数。换句话说,我喜欢摆脱整数模式环的陷阱,将结果带到普通整数,然后将其除以2。

代码语言:javascript
复制
def fast_exponentiation(c, L, q):
    Zq = IntegerModRing(q) # create Z_q
    g2 = c 
    result = 1
    while True:
        y = L % 2
        result = Zq(result) * Zq(g2 ** y)
        g2 = Zq(g2 * g2)
        L = L >> 1
        if L == 0:
            break
    return result

e = fast_exponentiation(2, 4, 6) 
print e / 2
EN

回答 1

Stack Overflow用户

发布于 2013-11-10 04:36:49

如果要再次将e转换为Integer,您有几个选择:调用Integer (目标对象),或者调用目标父对象ZZIntegerRing

代码语言:javascript
复制
sage: e
1
sage: parent(e)
Ring of integers modulo 6
sage: ZZ(e)
1
sage: parent(ZZ(e))
Integer Ring

因此:

代码语言:javascript
复制
sage: e = ZZ(e)
sage: e/2
1/2
sage: e//2
0

或者其他你想要的东西。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19882606

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档