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;
}
相关推荐
想拿大厂offer35 分钟前
【数据结构】第八节:链式二叉树
c语言·数据结构
忍界英雄1 小时前
LeetCode: 673.最长子序列的数量 动态规划 时间复杂度O(n*n)
算法·leetcode·动态规划
Renascence.4091 小时前
力扣--649.Dota2参议院
java·数据结构·算法·leetcode
山脚ice1 小时前
【Hot100】LeetCode—62. 不同路径
算法·leetcode·职场和发展
qincjun2 小时前
数据库第一章:库的操作
c语言·数据库·c++
Crossoads4 小时前
【数据结构】带你初步了解排序算法
c语言·开发语言·数据结构·算法·排序算法
lovPopcorn4 小时前
力扣每日一题:1372.二叉树中的最长交错路径
java·算法·leetcode
baidu_375528815 小时前
ubuntu20.04/22.04/24.04 docker 容器安装方法
linux·c语言·c++·嵌入式硬件
摆烂小白敲代码6 小时前
大一新生以此篇开启你的算法之路
c语言·数据结构·c++·人工智能·经验分享·算法
爱吃芝麻汤圆6 小时前
349. 两个数组的交集-LeetCode(C++)
c++·leetcode