zoukankan      html  css  js  c++  java
  • FZU1752 A^B mod C

     Problem Description  题目链接

    Given A,B,C, You should quickly calculate the result of A^B mod C. (1<=A,B,C<2^63).

     Input

    There are multiply testcases. Each testcase, there is one line contains three integers A, B and C, separated by a single space.

     Output

    For each testcase, output an integer, denotes the result of A^B mod C.

     Sample Input

    3 2 4
    2 10 1000

     Sample Output

    1
    24
    #include <iostream>
    #include <stdio.h>
    using namespace std;
    typedef long long LL;
    
    /*
        这道题有个大坑 如果直用快速幂 LL会爆 必须配合快速乘 其中快速乘如果%=还是会超时 使用-=会快点
        思路:快速幂+快速乘
    */
    
    //快速乘
    LL quickMul(LL a, LL b, LL mod) {
        LL res = 0;
        while (b)
        {
            if (b & 1) {
                res += a;
                //注意%= 还得用快速求余  于是干脆用-=
                if (res >= mod)
                    res -= mod; //大于减mod
            }
            a <<= 1;
            if (a >= mod)
                a -= mod;
            b >>= 1;
        }
        return res;
    }
    
    //快速幂
    LL quickPow(LL a, LL b, LL mod)
    {
        LL res = 1;
        a %= mod;
        while (b)
        {
            if (b & 1) {
                res = quickMul(res, b, mod);
            }
            b >>= 1;
            a = quickMul(a, a, mod);
        }
        return res;
    }
    
    int main()
    {
        LL a, b, c, res;
        while (~scanf("%I64d%I64d%I64d", &a, &b, &c))
        {
            //注意快速幂 以及LL的时候快速乘
            res = quickPow(a,b,c);
            printf("%I64d
    ", res);
        }
    }
     
  • 相关阅读:
    设计模式:访问者模式
    设计模式:解释器模式
    设计模式:享元模式
    设计模式:中介者模式
    设计模式:职责链模式
    设计模式:命令模式
    设计模式:桥接模式
    设计模式:单例模式
    设计模式:迭代器模式
    设计模式:组合模式
  • 原文地址:https://www.cnblogs.com/dlvguo/p/12757610.html
Copyright © 2011-2022 走看看