modfunc.cpp

来自「任意精度计算的实现」· C++ 代码 · 共 26 行

CPP
26
字号
#include "ap.h"


// Overloaded modint power
// Uses standard O(log exp) scheme
// For extreme portability this quite slow, so avoid whenever possible
modint pow (modint base, rawtype exp)
{
    modint r;

    if (exp == 0) return 1;

    while (!bigshr (&exp, &exp, 1))
        base *= base;

    r = base;

    while (exp > 0)
    {
        base *= base;
        if (bigshr (&exp, &exp, 1)) r *= base;
    }

    return r;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?