码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 快速幂的模板


    例题:数值的整数次方

    原题链接:力扣16
    实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,xn)。不得使用库函数,同时不需要考虑大数问题。

    示例 1:
    输入:x = 2.00000, n = 10
    输出:1024.00000
    示例 2:
    输入:x = 2.10000, n = 3
    输出:9.26100
    示例 3:
    输入:x = 2.00000, n = -2
    输出:0.25000
    解释:2-2 = 1/22 = 1/4 = 0.25

    提示:
    -100.0 < x < 100.0
    -231<= n <= 231-1
    -104<= xn<= 104

    思想:

    xn实际上可以转换成如下所示:

    n的二进制表示为:bm…b3b2b1,即n=2b1+2b2+…+2bm;

    xn=xbm…b3b2b1=xbm * …*xb3 * xb2 * xb1;

    所以我们只需要把n的二进制表示分解出来,就可以表示出xn;

    例如:210=22+8=22 * 28;

    模板:

        public double myPow(double x, int n) {
        if(x==0) return x;
        long b=n;//因为n有可能等于-2^31^在n=-n时会溢出,所以用long b来接受,之后再执行b=-b;
        if(b<0){
            b=-b;
            x=1/x;
        }
        double res=1;
        while(b>0){
        if((b&1)==1){//如果b的对应二进制位为1,则让res*x;
            res*=x;
        }
        b=b>>1;//遍历b的二进制位
        x*=x;//让x等于对应二进制位的值,如当10遍历到4个二进制位时(从右往左数)x=x^3^,每次遍历都让它自乘就可以达到这种效果;
        }
        return res;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    应用题:快速幂

    给定 n 组 ai,bi,pi,对于每组数据,求出 aibi mod pi 的值。

    输入格式
    第一行包含整数 n。
    接下来 n 行,每行包含三个整数 ai,bi,pi。

    输出格式
    对于每组数据,输出一个结果,表示 aibi mod pi 的值。
    每个结果占一行。

    数据范围
    1≤n≤100000,
    1≤ai,bi,pi≤2×109
    输入样例:
    2
    3 2 5
    4 3 9
    输出样例:
    4
    1

    import java.util.*;
    public class Main{
        public static void main(String[] args){
            Scanner sc=new Scanner(System.in);
            int n=sc.nextInt();
            for(int i=0;i<n;i++){
                int a=sc.nextInt();
                int b=sc.nextInt();
                int p=sc.nextInt();
                int res=1%b;
                while(b>0){
                   if(b%2==1) res = (int)((long)res*a%p);
                    a = (int)((long)a*a%p);
                    b=b>>1;
                }
                System.out.println(res);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
  • 相关阅读:
    阿里云服务器被ddos攻击,不断运行脚本占据系统资源,依附在某些应用绑定运行。无法获取根源。
    实验 2--创建数据库和表
    IPv6协议基本概念
    一个简单HTML5期末考核大作业,学生个人html静态网页制作代码
    Vim程序编辑器
    代码随想录刷题|完全背包理论基础 LeetCode 518. 零钱兑换II 377. 组合总和 Ⅳ
    扫地机器人遇瓶颈?科沃斯、石头科技“突围”
    Metasploit 操作及内网 Pivot图文教程
    Git的安装
    zookeeper 理论合集
  • 原文地址:https://blog.csdn.net/weixin_54575205/article/details/126669398
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号