• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

Tricker_5

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

快速幂与快速乘

 1 double quickMul(double x, long long N) {
 2     double ans = 1.0;
 3     double x_ = x;
 4     // 在对 N 进行二进制拆分的同时计算答案
 5     while (N > 0) {
 6         if (N & 1) {
 7             // 如果 N 二进制表示的最低位为 1,那么需要计入贡献
 8             ans *= x_;
 9         }
10         // 不断地平方
11         x_ *= x_;
12         // 舍弃 N 二进制表示的最低位,这样我们每次只要判断最低位即可
13         N >>= 1;
14     }
15     return ans;
16 }

算法的本质是每次将已有的结果翻倍相乘(加),因此将幂次或者乘数视为二进制是非常直观又巧妙的做法,每次翻一番查看对应进制位的数是否为1,若是则做简单的补充,如此循环反复。

posted on 2022-07-18 19:16  Tricker_5  阅读(28)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3