快速幂算法(普通幂算法进阶版)

快速幂算法(普通幂算法进阶版)

具体要求:求a^b的后三位数。

基本算法思想:

  • 减少指数大小,减少循环次数。

2 10 2^{10} 210为例。

当指数为偶数时,先将指数除以二,再将底数平方。

2 10 = 4 5 2^{10}=4^{5} 210=45

当指数为奇数时,将指数减一再除以二,提出底数,再将底数平方。

4 5 = 4 × 1 6 2 4^{5}=4\times 16^{2} 45=4×162

一直运算下去直至: 2 10 = 4 × 25 6 1 2^{10}=4\times 256^{1} 210=4×2561

这样,循环操作从原来的10次减少到4次。快速幂运算极大提高了算法的运行速度。

  • 具体代码如下:
#include<iostream>
#include<time.h>
using namespace std;
long long fastpower(long long base,long long power)
{

    long long result=1;
    while(power>0)
    {
        if(power%2==0)
        {
            power/=2;
            base=base*base%1000;
        }
        else
        {
            power-=1;
            result=base*result%1000;
            power/=2;
            base=(base*base)%1000;
        }
    }
    return result;
}
int main()
{
    clock_t start,end;
    long long base,power;
    cout<<"请输入a的值和b的值:\n";
    cin>>base>>power;
    start=clock();
    cout<<base<<" 的 "<<power<<" 的后三位数为 "<<fastpower(base,power)<<endl;
    end=clock();
    cout<<"运行时间为:"<<double(end-start)/CLOCKS_PER_SEC;
    return 0;
}

位运算对代码运行速度进行优化:

  1. if…else语句中存在重复的语句,对重复语句进行优化。
// 重复语句
power/=2;
base=(base*base)%1000;

// 优化之后
if(power%2==1)
{
    power-=1;
    result=base*result%1000;
}
power/=2;
base=(base*base)%1000;
  1. 当power为奇数时,power不在减1除2变换成偶数,根据C++编译机制直接将power除2,会自动向下取整。
// 优化之后
if(power%2==1)
{
    result=base*result%1000;
}
power/=2;
base=(base*base)%1000;
  1. 用位运算取代除运算,由于位运算是直接使用通过机器指令实现,运算速度快于其他运算。
//优化之后
if(power&1)
{
    result=base*result%1000;
}
power>>=1;
base=(base*base)%1000;
  • 优化之后的具体代码如下
#include<iostream>
#include<time.h>
using namespace std;
long long fastpower(long long base,long long power)
{

    long long result=1;
    while(power>0)
    {
        if(power&1)
        {
            result=base*result%1000;
        }
        power>>=1;
        base=(base*base)%1000;
     }
    return result;
}
int main()
{
    clock_t start,end;
    long long base,power;
    cout<<"请输入a的值和b的值:\n";
    cin>>base>>power;
    start=clock();
    cout<<base<<" 的 "<<power<<" 的后三位数为 "<<fastpower(base,power)<<endl;
    end=clock();
    cout<<"运行时间为:"<<double(end-start)/CLOCKS_PER_SEC;
    return 0;
}

power&1当power为偶数时该结果为0,为奇数时为1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值