蓝桥杯JAVA组备赛模板1:快速幂

快速幂:

复制代码
    static long gcd(long a, long b) {
        return b == 0 ? a : gcd(b, a % b);
    }
    static long lcm(long a, long b) {
        return (a / gcd(a, b)) * b;
    }
    
    //快速幂
    static long powl(long a, int b) {
        if (a == 0)
            return 0;
        long ans = 1;
        while (b > 0) {
            if ((b & 1) > 0)
                ans *= a;
            a *= a;
            b >>= 1;
        }
        return ans;
    }

关于这些函数的解释如下:

  • gcd(long a, long b): 这个函数用于计算两个整数 ab 的最大公约数。它是通过辗转相除法(欧几里德算法)实现的。当 b 为 0 时,返回 a,否则递归调用自身,并传入 ba 除以 b 的余数。
  • lcm(long a, long b): 这个函数用于计算两个整数 ab 的最小公倍数。它利用了最大公约数的性质,即两个数的乘积等于它们的最大公约数与最小公倍数的积。因此,函数首先通过 gcd 函数计算出最大公约数,然后用 a * b / gcd(a, b) 计算最小公倍数。
  • powl(long a, int b): 这个函数是一个快速幂函数,用于计算 ab 次幂。它采用了二进制指数的思想,将指数 b 转换为二进制表示,并通过迭代的方式累乘得到结果。
相关推荐
lld9510273 分钟前
(三)本地策略框架
java·服务器·数据库
SoftLipaRZC4 分钟前
C语言文件:文件操作完全指南
android·java·c语言
零陵上将军_xdr6 分钟前
API 签名防重放机制:基于 HMAC-SHA256 的设计与实现
java·学习·安全架构
ch.ju7 分钟前
Java程序设计(第3版)第四章——set-get方法
java·开发语言
lpd_lt7 分钟前
如何让AI生成项目的单元测试,propmt技巧详解
java·人工智能·单元测试·ai编程
_日拱一卒14 分钟前
LeetCode:17电话号码的字母组合
java·数据结构·算法·leetcode·职场和发展
我是一颗柠檬16 分钟前
【Java项目技术亮点】Outbox事件驱动模式:解决分布式事务的终极方案
java·开发语言·分布式·后端·中间件·kafka
_Evan_Yao18 分钟前
为 LLM 预留“插座”:设计可插拔的 AI 能力底座
java·人工智能·后端·python
我登哥MVP19 分钟前
Spring Boot 从“会用”到“精通”:Converter 原理
java·spring boot·servlet·maven·mybatis·converter
Clf丶忆笙22 分钟前
搭建支持多语言开发的Quarkus环境:Java、Kotlin与Scala全栈指南
java·开发语言·云原生·kotlin·scala·quarkus