当前位置: 首页>>代码示例>>C++>>正文


C++ BigInteger::modInverse方法代码示例

本文整理汇总了C++中BigInteger::modInverse方法的典型用法代码示例。如果您正苦于以下问题:C++ BigInteger::modInverse方法的具体用法?C++ BigInteger::modInverse怎么用?C++ BigInteger::modInverse使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在BigInteger的用法示例。


在下文中一共展示了BigInteger::modInverse方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1:

ECPoint ECPoint::operator+(const ECPoint& p2) const
{
    ECPoint p1 = *this;

    ECPoint p3;
    p3.a = p1.a;
    p3.b = p1.b;
    p3.FieldChar = p1.FieldChar;

    BigInteger dy = p2.y - p1.y;
    BigInteger dx = p2.x - p1.x;

    if (dx < 0)
        dx = dx + p1.FieldChar;

    if (dy < 0)
        dy = dy + p1.FieldChar;

    BigInteger m = (dy * dx.modInverse(p1.FieldChar)) % p1.FieldChar;

    if (m < 0)
        m = m + p1.FieldChar;

    p3.x = (m * m - p1.x - p2.x) % p1.FieldChar;
    p3.y = (m * (p1.x - p3.x) - p1.y) % p1.FieldChar;

    if (p3.x < 0)
        p3.x = p3.x + p1.FieldChar;

    if (p3.y < 0)
        p3.y = p3.y + p1.FieldChar;

    return p3;
}
开发者ID:alexript,项目名称:crypto-gost,代码行数:34,代码来源:ECPoint.cpp

示例2: Double

ECPoint ECPoint::Double() const
{
    ECPoint p = *this;

    ECPoint p2;
    p2.a = p.a;
    p2.b = p.b;
    p2.FieldChar = p.FieldChar;

    BigInteger dy = p.x * p.x * 3 + p.a;
    BigInteger dx = p.y * 2;

    if (dx < 0)
        dx = dx + p.FieldChar;

    if (dy < 0)
        dy = dy + p.FieldChar;

    BigInteger m = (dy * dx.modInverse(p.FieldChar)) % p.FieldChar;

    p2.x = (m * m - p.x - p.x) % p.FieldChar;
    p2.y = (m * (p.x - p2.x) - p.y) % p.FieldChar;

    if (p2.x < 0)
        p2.x = p2.x + p.FieldChar;

    if (p2.y < 0)
        p2.y = p2.y + p.FieldChar;

    return p2;
}
开发者ID:alexript,项目名称:crypto-gost,代码行数:31,代码来源:ECPoint.cpp


注:本文中的BigInteger::modInverse方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。