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;
}
相关推荐
lengjingzju14 小时前
一网打尽Linux IPC(四):POSIX IPC
linux·服务器·c语言
POLITE314 小时前
Leetcode 3.无重复字符的最长子串 JavaScript (Day 4)
javascript·算法·leetcode
sin_hielo14 小时前
leetcode 756(枚举可填字母)
算法·leetcode
Jeremy爱编码14 小时前
leetcode热题子集
算法·leetcode·职场和发展
Tisfy15 小时前
LeetCode 756.金字塔转换矩阵:深度优先搜索
leetcode·矩阵·深度优先
努力学算法的蒟蒻15 小时前
day48(12.29)——leetcode面试经典150
算法·leetcode·面试
自信1504130575915 小时前
数据结构初阶之单链表
c语言·数据结构
java修仙传15 小时前
力扣hot100:有效的括号
算法·leetcode·职场和发展
圣保罗的大教堂15 小时前
leetcode 756. 金字塔转换矩阵 中等
leetcode
Dream it possible!15 小时前
LeetCode 面试经典 150_分治_合并 K 个升序链表(108_23_C++_困难)
c++·leetcode·链表·面试·分治