题目 2154: 取余运算

题目描述:

输入b,p,k的值,求b^p mod k的值。其中b,p,k×k为长整型数。

解题思路:

  • 如果指数为奇数,那么结果乘以当前的底数,指数除以2(整除运算)。
  • 如果指数为偶数,那么底数变为原来底数的平方,指数除以2。

代码:

分治算法

java 复制代码
package lanqiao;

import java.math.BigInteger;
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        long b = sc.nextInt();
        long p = sc.nextInt();
        long k = sc.nextInt();

        System.out.println(b + "^" + p + " mod " + k + "=" + f(b,p,k));

    }
    public static long f(long b,long p,long k)
    {
        long ans = 1;
        while(p > 0)
        {
            if(p % 2 == 1)
                ans = ans * b % k;
            b = b * b % k;
            p /= 2;
        }
        return ans;
    }
}
相关推荐
普通网友几秒前
C++模块化设计原则
开发语言·c++·算法
864记忆3 分钟前
Qt c++的基础语法有哪些?
开发语言·c++·qt
江公望3 分钟前
Qt QHostInfo::lookupHost()函数,10分钟讲清楚
开发语言·qt·qml
倦王6 分钟前
力扣日刷251117
算法·leetcode·职场和发展
C++chaofan10 分钟前
项目中基于redis实现缓存
java·数据库·spring boot·redis·spring·缓存
MZ_ZXD00120 分钟前
springboot流浪动物救助平台-计算机毕业设计源码08780
java·spring boot·后端·python·spring·flask·课程设计
没有bug.的程序员23 分钟前
Spring 全家桶在大型项目的最佳实践总结
java·开发语言·spring boot·分布式·后端·spring
在坚持一下我可没意见25 分钟前
Spring IoC 入门详解:Bean 注册、注解使用与 @ComponentScan 配置
java·开发语言·后端·spring·rpc·java-ee
Genevieve_xiao25 分钟前
【数据结构】【xjtuse】八股文单元小测
数据结构·算法
加洛斯35 分钟前
前端小知识003:JS中 == 与 === 的区别
开发语言·前端·javascript