当前位置: 首页 > news >正文

信奥赛C++提高组csp-s之快速幂

信奥赛C++提高组csp-s之快速幂

题目描述

给你三个整数a , b , p a,b,pa,b,p,求a b m o d p a^b \bmod pabmodp

输入格式

输入只有一行三个整数,分别代表a , b , p a,b,pa,b,p

输出格式

输出一行一个字符串a^b mod p=s,其中a , b , p a,b,pa,b,p分别为题目给定的值,s ss为运算结果。

输入输出样例 1
输入 1
2 10 9
输出 1
2^10 mod 9=7
说明/提示

样例解释

2 10 = 1024 2^{10} = 1024210=10241024 m o d 9 = 7 1024 \bmod 9 = 71024mod9=7

数据规模与约定

对于100 % 100\%100%的数据,保证0 ≤ a , b < 2 31 0\le a,b < 2^{31}0a,b<231a + b > 0 a+b>0a+b>02 ≤ p < 2 31 2 \leq p \lt 2^{31}2p<231

AC代码1(迭代实现)

#include<bits/stdc++.h>usingnamespacestd;longlonga,b,p;// 快速幂取模函数longlongqpow(longlonga,longlongb){longlongans=1;// 初始化结果为1// 当指数b不为0时循环while(b){// 如果b的二进制最低位为1(即b为奇数)if(b&1){ans=ans*a%p;// 将当前的a乘到结果中,并取模ans%=p;// 再次取模确保结果正确(实际上前一步已经取模,这步是冗余的)}a=a*a%p;// 将底数平方,并取模b>>=1;// 将指数右移一位(相当于除以2)}returnans;// 返回最终结果}intmain(){// 读取输入:底数a,指数b,模数pcin>>a>>b>>p;// 输出结果,格式为:a^b mod p=计算结果cout<<a<<"^"<<b<<" mod "<<p<<"="<<qpow(a,b);return0;}

功能分析

快速幂算法原理:
  1. 二进制分解思想:将指数b用二进制表示,通过不断平方和相乘来计算结果
  2. 时间复杂度:O(log b),远优于朴素的O(b)方法
  3. 空间复杂度:O(1)
算法步骤:
  1. 初始化结果ans = 1
  2. 当指数b > 0时循环:
    • 如果b是奇数(b & 1 == 1),将当前底数a乘到结果ans中
    • 将底数a平方(a = a * a)
    • 将指数b右移一位(b = b / 2)
  3. 返回最终结果
取模运算的重要性:
  • 防止数值溢出
  • 满足题目要求的模运算

快速幂算法与倍增算法的关系

快速幂算法本质上是倍增算法思想在幂运算上的具体应用

1. 倍增算法思想

倍增算法的核心思想是:通过已知的小规模结果,通过"翻倍"的方式快速得到大规模结果,从而将线性复杂度优化到对数复杂度。

基本模式:

  • 从基础情况开始
  • 每次将规模扩大一倍
  • 通过组合小规模结果得到大规模结果
2. 快速幂作为倍增的应用

迭代快速幂的倍增过程:

// 倍增过程:a, a^2, a^4, a^8, a^16, ...while(b){if(b&1)ans=ans*a%p;// 组合阶段a=a*a%p;// 倍增阶段:当前值平方b>>=1;// 规模减半}

更多系列知识,请查看专栏:《信奥赛C++提高组csp-s知识详解及案例实践》:
https://blog.csdn.net/weixin_66461496/category_13113932.html


各种学习资料,助力大家一站式学习和提升!!!

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"########## 一站式掌握信奥赛知识! ##########";cout<<"############# 冲刺信奥赛拿奖! #############";cout<<"###### 课程购买后永久学习,不受限制! ######";return0;}

1、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html

2、csp信奥赛冲刺一等奖有效刷题题解:

CSP信奥赛C++初赛及复赛高频考点真题解析(持续更新):https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

CSP信奥赛C++一等奖通关刷题题单及题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

3、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转


GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html

4、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

· 文末祝福 ·

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"跟着王老师一起学习信奥赛C++";cout<<" 成就更好的自己! ";cout<<" csp信奥赛一等奖属于你! ";return0;}
http://www.jsqmd.com/news/245753/

相关文章:

  • 中小企业降本增效:bge-m3免费镜像部署实战指南
  • 使用ASP.NET Core MVC实现实时表单自动填充
  • 语音数据预处理全攻略|结合FRCRN镜像实现高质量降噪切片
  • Hunyuan vs DeepSeek:开源翻译模型选型对比评测
  • PaddleOCR-VL API快速调用:免部署直接测试,1块钱起
  • Hunyuan-HY-MT1.8B资源占用分析:CPU/GPU协同调度实战
  • 上下文为王:企业数字化与内容战略的核心指南
  • YOLO-v5技术解析:You Only Look Once架构原理深度剖析
  • AI超清画质增强避雷贴:新手常犯的5个部署错误及解决方法
  • 8G显存够用!DeepSeek-R1-Distill-Qwen-1.5B边缘设备部署指南
  • 吐血推荐继续教育AI论文写作软件TOP10:选对工具轻松过关
  • 惊艳!DeepSeek-R1生成的代码逻辑清晰度实测
  • 信奥赛C++提高组csp-s之倍增算法
  • 《小城大事》热度持续高走,黄晓明号召力再次显现
  • Keil5芯片包下载在PLC开发中的应用
  • CAM++音频预处理:重采样至16kHz标准化流程
  • Open-AutoGLM能力测评:文本、图像、操作理解多维评估
  • 通义千问2.5-7B智能写作:新闻稿生成实战
  • 无障碍应用开发:IndexTTS2视障辅助阅读系统搭建
  • NewBie-image-Exp0.1工具测评:Diffusers+Transformers集成体验指南
  • ACE-Step音乐生成实战:小白10分钟上手,云端GPU按需付费
  • 保姆级教程:用通义千问3-14B微调专属AI助手
  • 树的练习1--------965单值二叉树
  • 如何用自然语言分割任意物体?sam3大模型镜像快速上手指南
  • AI Agent 在汽车上的典型应用场景,研发入门
  • PyTorch-2.x镜像让多版本CUDA切换变得异常简单
  • YOLOv8视频分析实战:云端GPU处理4K视频不卡顿
  • TouchGFX入门必读:官方Demo分析解读
  • AI隐私卫士深度测评:打码效果/速度/价格全面对比
  • 测试开机启动脚本Go语言微服务注册与发现机制