题目 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;
    }
}
相关推荐
研☆香1 分钟前
深入解析JavaScript的arguments对象
开发语言·前端·javascript
zzzgw_20012 分钟前
io_uring的机理和跟epoll的对比
java·开发语言
pandarking2 分钟前
[CTF]攻防世界:easy_laravel 学习
java·学习·web安全·laravel·ctf
Han.miracle3 分钟前
数据结构与算法--006 和为s的两个数字(easy)
java·数据结构·算法·和为s的两个数字
AAA简单玩转程序设计6 分钟前
Java集合“坑王”:ArrayList为啥越界还能浪?
java·前端
AAA简单玩转程序设计7 分钟前
别再把Java枚举当“花瓶”!它能办大事
java·前端
Java天梯之路9 分钟前
Spring Boot 启动流程源码解析:从 `main()` 到 Web 服务就绪
java·spring boot·面试
漂亮的小碎步丶9 分钟前
【3】Spring事务管理
java·数据库·spring
WZTTMoon10 分钟前
Spring Boot Swagger3 使用指南
java·spring boot·后端·swagger3
Java天梯之路11 分钟前
Spring Boot 钩子全集实战(一):构造与配置阶段
java·spring boot·面试