蓝桥杯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 转换为二进制表示,并通过迭代的方式累乘得到结果。
相关推荐
weixin_lizhao7 分钟前
50天独立打造企业级API网关(二):安全防护体系与弹性设计
java·spring boot·安全·spring cloud·gateway
逸Y 仙X36 分钟前
文章二十四:Elasticsearch查询排序应用实战e
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
aXin_ya1 小时前
微服务 第十天 (Redis多级缓存)
java·redis·微服务
逸Y 仙X2 小时前
文章二十五:ElasticSearch 分页查询
java·大数据·数据库·elasticsearch·搜索引擎·全文检索
ch.ju2 小时前
Java programming(The third edition) Chapter Two——Null return value
java·开发语言
1.14(java)2 小时前
Spring事务和事务传播机制
java·数据库·spring
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第34题:String、StringBuffer和StringBuilder的区别是什么
java·后端·面试
晓庆的故事簿2 小时前
JAVA搭配RabbitMQ使用
java·rabbitmq·java-rabbitmq
折哥的程序人生 · 物流技术专研2 小时前
第3篇:为何要配置环境变量?
java·开发语言·后端·面试
渔民小镇2 小时前
4 行代码接入 Spring —— ionet 的生态融合之道
java·服务器·分布式·游戏