题解 | #快速乘#

快速乘

https://www.nowcoder.com/practice/043c66e95fe548d0b8e56c1830330f93

n = int(input())
def cal(a, b, p):
    if b == 0:
        return 0
    while b != 0:
        if b % 2 == 0:
            b = b // 2
            c = cal(a, b, p)
            return (c + c) % p
        else:
            b = (b - 1) // 2
            c = cal(a, b, p)
            return (c + c + a % p) % p
for i in range(n):
    s = list(map(int, input().split()))
    a, b, p = s[0], s[1], s[2]
    print(cal(a, b, p))

全部评论

相关推荐

牛客41406533...:回答他在课上学,一辈子待在学校的老教授用三十年前的祖传PPT一字一句的讲解,使用谭浩强红皮书作为教材在devc++里面敲出a+++++a的瞬间爆出114514个编译错误来学这样才显得专业
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务