当前位置:主页 > c/c++教程 > c++快速幂算法

c++入门必学算法之快速幂思想及实现

发布:2023-03-08 20:00:01 59


给网友们整理相关的编程文章,网友余寄瑶根据主题投稿了本篇教程内容,涉及到C++快速幂算法、c++、快速幂、c++幂运算、c++快速幂算法相关内容,已被300网友关注,涉猎到的知识点内容可以在下方电子书获得。

c++快速幂算法

一、什么是快速幂

快速幂算法是用来快速计算指数表达式的值的,例如 210000000,普通的计算方法 2*2*2*2…乘10000000次,如果一个数字的计算都要计算那么多次的话,那么这个程序一定是失败的。

学完快速幂之后就可以用几十次计算求出答案了

二、快速幂思想及实现

快速幂思想其实很简单,就是公式的转换

1、当指数是偶数时,我们可以让指数除以2,底数乘以底数

2、当指数是奇数时,我们可以将指数变为奇数

例如 210

  • 指数是偶数,210 = 45
  • 指数是奇数,45 = 4 * 44
  • 指数是偶数, 4 * 44 = 4 * 162
  • 指数是偶数,4 * 162 = 4 * 2561
  • 指数是奇数, 4 * 2561=4 * 256 * 2560
  • 指数为0时停止,那么答案就是计算 4 * 256 = 1024

下面代码就是模拟这个过程:

 #include//c++标准头文件,可以使用cout,cin等标准库函数 
using namespace std;//命名空间,防止重名给程序带来各种隐患,使用cin,cout,stack,map,set,vector,queue时都要使用
long long fpow(long long a,long long b){//a是底数,b是指数 
	long long ans=1;//初始化答案为1
	while(b){//当指数不为0时执行
		if(b%2==0){//指数为偶数时,指数除以2,底数乘以2
			b/=2;
			a*=a; 
		}else{//指数为奇数时,分离指数,ans乘以底数
			ans*=a; 
			b--;
		}
	} 
	return ans;//ans就是答案 
}
int main(){
	long long n,m;
	cin>>n>>m;
	cout<

3、快速幂精简模板

#include
using namespace std;
long long fpow(long long a,long long b){
	long long ans=1;
	while(b){
		if(b&1)ans*=a;
		b>>=1;
		a*=a;
	} 
	return ans;
}
int main(){
	long long n,m;
	cin>>n>>m;
	cout<

总结

到此这篇关于c++入门必学算法之快速幂思想及实现的文章就介绍到这了,更多相关c++快速幂算法内容请搜索码农之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持码农之家!


参考资料

相关文章

  • C++成员函数后面加override问题

    发布:2023-03-09

    这篇文章主要介绍了C++成员函数后面加override问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教


  • C++ getcwd函数获取项目运行路径方法详解

    发布:2023-03-03

    在Linux下做QT项目时,需要获取项目的运行路径,于是用getcwd函数进行获取,然后在Windows下进行测试,发现获取到的是程序的项目路径,即代码文件路径,然后再Linux QT中测试,获取到的又是运行路径,这就很纳闷了。经过再三测试,终于发现了原因


  • C C++算法题解LeetCode1408数组中的字符串匹配

    发布:2023-03-04

    这篇文章主要为大家介绍了C C++算法题解LeetCode1408数组中的字符串匹配示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • C++运行时类型识别与转换实现方法

    发布:2023-03-03

    运行时类型识别可能被认为是C++中一个”次要“的特征,当程序员在编程过程中陷入非常困难的境地时,实用主义将会帮助他走出困境


  • C++ IO设备读写功能实现详解

    发布:2023-03-10

    C++的文件IO(Input,Output)操作就是指对文件进行读写(输入与输出)的操作。输入就是从磁盘上的文件中读取内容到内存中。输出就是将内存中的数据内容输出或者说写入到磁盘的文件中,这篇文章主要介绍了C++ IO设备读写功能实现


  • C++中的数字转字符串to_string

    发布:2023-03-10

    这篇文章主要介绍了C++中的数字转字符串to_string,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教


  • 深入理解c++中virtual关键字

    发布:2022-09-23

    给网友朋友们带来一篇关于c++的教程,本篇文章主要是对c++中virtual关键字进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助


  • C++变量存储的生命周期与作用域实例代码精讲

    发布:2023-03-06

    这篇文章主要介绍了C++变量存储的生命周期与作用域,从创建到消亡的完整过程,例如人从出生到死亡的整个过程就是一个生命周期。本文将通过示例为大家详细讲讲,感兴趣的可以学习一下


网友讨论