【蓝桥云课】快速幂

news/2025/1/15 6:25:43/

问题描述:快速求aba^bab

方法一:常规方法相乘a∗a∗a∗a∗...∗aa*a*a*a*...*aaaaa...a
方法二:分治方法求aba^bab

ab={1,b=0a,b=1ab2⋅ab2,b为偶数ab−12⋅ab+12,b为奇数a^b=\begin{cases} 1& \text{,b=0}\\ a& \text{,b=1}\\ a^{\frac{b}{2}} · a^{\frac{b}{2} }& \text{,b为偶数}\\ a^{\frac{b-1}{2}} · a^{\frac{b+1}{2} }& \text{,b为奇数} \end{cases}ab=1aa2ba2ba2b1a2b+1,b=0,b=1,b为偶数,b为奇数

快速幂方法:扩底降幂方法

程序代码:

import java.util.Scanner;public class KuaiSuMi {public static void main(String[] args) {Scanner sc = new Scanner(System.in);while(sc.hasNext()) {int a=sc.nextInt();int b=sc.nextInt();int p=131;//计算a^bSystem.out.println(((int)Math.pow(a, b))%p);//系统自带计算方法System.out.println(funtion1(a,b));//常规方法System.out.println(funtion2(a,b));//分治方法System.out.println(funtion3(a,b,p));//(a^b)%pSystem.out.println(funtion4(a,b,p));//((a%p)(b%p))%pSystem.out.println(funtion5(a,b,p));//扩底降幂System.out.println(funtion6(a,b,p));//扩底降幂System.out.println(funtion7(a,b,p));//扩底降幂}}public static int funtion1(int a,int b) {int ans = 1;for(int i=1;i<=b;i++) ans = ans*a;return ans;}public static int funtion2(int a,int b) {if(b==0) return 1;if(b==1) return a;if(b%2==0) return funtion2(a, b/2)*funtion2(a, b/2);else return funtion2(a, (b-1)/2)*funtion2(a, (b+1)/2);}public static int funtion3(int a,int b,int p) {int ans = 1;for(int i=1;i<=b;i++) ans = ans*a;return ans%p;}public static int funtion4(int a,int b,int p) {int ans = 1;for(int i=1;i<=b;i++) ans = (ans*a)%p;return ans%p;}public static int funtion5(int a,int b,int p) {int ans = 1;while(b>0) {if(b%2==0) {a=a*a%p;//扩底b=b/2;//降幂} else {b=b-1;ans=ans*a%p;a=a*a%p;//扩底b=b/2;//降幂}}return ans;}public static int funtion6(int a,int b,int p) {int ans = 1;while(b>0) {if(b%2==1) ans=ans*a%p;a=a*a%p;//扩底b=b/2;//降幂}return ans;}public static int funtion7(int a,int b,int p) {int ans = 1;while(b>0) {if((b&1)!=0) ans=ans*a%p;a=a*a%p;//扩底b=b>>1;//降幂}return ans;}
}

http://www.ppmy.cn/news/28833.html

相关文章

linux下终端操作mysql数据库

目录 一&#xff0e;检查mysql是否安装 1. 查看文件安装路径 2. 查询运行文件所在路径(文件夹地址) 二&#xff0e;登录mysql 三&#xff0e;列出mysql全部用户 四&#xff0e;常用指令 &#xff11;&#xff0e;查看全部数据库 &#xff12;&#xff0e;选择数据库 …

离散数学---期末复习知识点

一、 数理逻辑 [复习知识点] 1、命题与联结词&#xff08;否定&#xffe2;、析取∨、合取∧、蕴涵→、等价↔&#xff09;&#xff0c;命题(非真既假的陈述句),复合命题(由简单命题通过联结词联结而成的命题) 2、命题公式与赋值&#xff08;成真、成假&#xff09;&#x…

【Android源码面试宝典】MMKV从使用到原理分析(一)

去年,我们写过一篇文章,对于android原生提供的key-value存储API SharePreference,进行了从使用到原理的深入分析,同时对其中存在的ANR问题、存取慢等问题,进行了深入的探索、总结。但是之前的文章,我们仅仅指出了问题,没有给大家提供解决方案,也就是说,SharePreferenc…

一个线程两次调用start()方法会出现什么情况?

第17讲 | 一个线程两次调用start()方法会出现什么情况&#xff1f; 今天我们来深入聊聊线程&#xff0c;相信大家对于线程这个概念都不陌生&#xff0c;它是 Java 并发的基础元素&#xff0c;理解、操纵、诊断线程是 Java 工程师的必修课&#xff0c;但是你真的掌握线程了吗&am…

spring boot 配合element ui vue实现表格的批量删除(前后端详细教学,简单易懂,有手就行)

目录 一.前言&#xff1a; 二. 前端代码&#xff1a; 2.1.element ui组件代码 2.2删除按钮 2.3.data 2.4.methods 三.后端代码&#xff1a; 一.前言&#xff1a; 研究了其他人的博客&#xff0c;找到了一篇有含金量的&#xff0c;进行了部分改写实现前后端分离&#xff0…

Learining C++ No.12【vector】

引言&#xff1a; 北京时间&#xff1a;2023/2/27/11:42&#xff0c;高数考试还在进行中&#xff0c;我充分意识到了学校的不高级&#xff0c;因为题目真的没什么意思&#xff0c;虽然挺平易近人&#xff0c;但是……&#xff0c;考试期间时间比较放松&#xff0c;所以不能耽误…

【算法】【数组与矩阵模块】求数组中需要排序的最短子数组长度

目录前言问题介绍解决方案代码编写java语言版本c语言版本c语言版本思考感悟写在最后前言 当前所有算法都使用测试用例运行过&#xff0c;但是不保证100%的测试用例&#xff0c;如果存在问题务必联系批评指正~ 在此感谢左大神让我对算法有了新的感悟认识&#xff01; 问题介绍 …

攻不下dfs不参加比赛(七)

标题 为什么练dfs题目总结重点为什么练dfs 相信学过数据结构的朋友都知道dfs(深度优先搜索)是里面相当重要的一种搜索算法,可能直接说大家感受不到有条件的大家可以去看看一些算法比赛。这些比赛中每一届或多或少都会牵扯到dfs,可能提到dfs大家都知道但是我们为了避免眼高手…