C语言 | Leetcode C语言题解之第372题超级次方

题目:

题解:

cpp 复制代码
//计算a的b次方
int mypow(int a, int b){
    a = a % 1337; // 防止a过大超出规模
    int ret = 1;
    for(int i = 0; i < b; i++){
        ret *= a;
        ret = ret % 1337; //防止超出规模
    }
    return ret;
}
//整体计算
int superPow(int a, int* b, int bSize){
    if(a == 1) return 1;
    int sum = 1;
    for(int i = 0; i < bSize; i++){
        //由例子可知(x的10次方的次数)为(bSize-1),所以写在最开始,使得多出来的一次(循环次数为bSize)为计算1的十次方
        sum = mypow(sum, 10); 
        sum *= mypow(a, b[i]);
        sum = sum % 1337; //防止超出规模
    }


    return sum;
}
相关推荐
啦哈拉哈4 小时前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
luj_17688 小时前
R语言生态优势与学习曲线分析
c语言·开发语言·网络·经验分享·算法
叶子野格9 小时前
《C语言学习:文件操作》16
c语言·开发语言·c++·学习·visual studio
AI科技星9 小时前
万有引力G与真空介电常数ε0全维度完整关系式汇编(基于v=c螺旋时空理论)
c语言·开发语言·前端·javascript·网络·汇编·electron
C^h9 小时前
6轴达妙机械臂
c语言
叶子野格9 小时前
《C语言学习:位运算》17
c语言·开发语言·c++·学习·visual studio
社交怪人11 小时前
【最大数】信息学奥赛一本通C语言解法(题号2056)
c语言
社交怪人11 小时前
【判断正负】信息学奥赛一本通C语言解法(题号1039)
c语言
龙腾AI白云12 小时前
数字孪生:虚拟调试,真实交付
c语言·virtualenv·知识图谱
我不是懒洋洋12 小时前
手写一个异步日志库:从printf到高性能无锁日志
java·c语言·开发语言·c++·visual studio