蓝桥杯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 转换为二进制表示,并通过迭代的方式累乘得到结果。
相关推荐
不光头强1 分钟前
mybatis中的延迟加载和一二级缓存
java·tomcat·mybatis
奋斗的小乌龟4 分钟前
k8s测试环境开启远程调试
java·spring
IDOlaoluo6 分钟前
JK2连接器使用教程:jakarta-tomcat-connectors-jk2-src-current.zip 安装配置步骤详解
java·tomcat
M***29919 分钟前
【Spring Boot】SpringBoot自动装配-Import
java·spring boot·后端
墨雪不会编程10 分钟前
C++基础语法篇五 ——类和对象
java·前端·c++
一 乐11 分钟前
农产品销售|农产品供销|基于SprinBoot+vue的农产品供销系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot
是小崔啊12 分钟前
【SAA】01 - Spring Ai Alibaba快速入门
java·人工智能·spring
爱学习的小可爱卢13 分钟前
JavaEE进阶——Cookie与Session:Web安全的双刃剑
java·javaee进阶
semantist@语校13 分钟前
第五十一篇|构建日本语言学校数据模型:埼玉国际学院的城市结构与行为变量分析
java·大数据·数据库·人工智能·百度·ai·github
LSL666_14 分钟前
4 Maven 项目构建与配置要点总结
java·tomcat·maven