news 2026/4/16 13:58:06

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
信奥赛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;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:41:54

OCR性能与效率兼得|DeepSeek-OCR-WEBUI镜像实践指南

OCR性能与效率兼得&#xff5c;DeepSeek-OCR-WEBUI镜像实践指南 1. 引言&#xff1a;OCR技术演进与DeepSeek的创新路径 光学字符识别&#xff08;OCR&#xff09;作为连接物理文档与数字信息的关键技术&#xff0c;近年来在深度学习推动下实现了质的飞跃。传统OCR系统依赖于独…

作者头像 李华
网站建设 2026/3/25 13:15:22

如何高效实现中文语音识别?科哥开发的FunASR镜像一键上手

如何高效实现中文语音识别&#xff1f;科哥开发的FunASR镜像一键上手 1. 背景与需求分析 随着人工智能技术的发展&#xff0c;语音识别在智能客服、会议记录、视频字幕生成等场景中发挥着越来越重要的作用。尤其是在中文语音处理领域&#xff0c;高准确率、低延迟的自动语音识…

作者头像 李华
网站建设 2026/3/22 16:25:32

Qwen2.5-0.5B-Instruct缓存机制:提升重复查询效率的部署优化

Qwen2.5-0.5B-Instruct缓存机制&#xff1a;提升重复查询效率的部署优化 1. 引言&#xff1a;轻量级大模型的推理挑战与优化需求 1.1 边缘设备上的大模型部署瓶颈 Qwen2.5-0.5B-Instruct 是阿里通义千问 Qwen2.5 系列中体量最小的指令微调模型&#xff0c;拥有约 5 亿&#…

作者头像 李华
网站建设 2026/4/3 4:47:54

Open-AutoGLM实战:自动发布小红书内容全过程分享

Open-AutoGLM实战&#xff1a;自动发布小红书内容全过程分享 1. 背景与目标 随着社交媒体运营的复杂化&#xff0c;内容创作者面临重复性高、耗时长的操作任务。以小红书为例&#xff0c;每日发布图文、互动评论、数据统计等流程若全部手动完成&#xff0c;效率低下且容易出错…

作者头像 李华
网站建设 2026/4/16 13:42:30

如何实现进度提示?Super Resolution异步响应开发指南

如何实现进度提示&#xff1f;Super Resolution异步响应开发指南 1. 引言 1.1 业务场景描述 在图像处理类AI应用中&#xff0c;用户上传低分辨率图片后&#xff0c;系统需要执行耗时的超分辨率重建任务。以基于OpenCV EDSR模型的Super Resolution服务为例&#xff0c;3倍放大…

作者头像 李华
网站建设 2026/3/22 13:33:56

解密SQL中的时间计算:以开发请求为例

在企业内部,IT部门通常需要处理来自各个业务单位的开发请求。这些请求会在系统中经历多个阶段,每个阶段都有其特定的流程和时间要求。本文将详细介绍如何使用SQL查询来计算和分析这些请求的处理时间,并以一个实际案例为例。 案例背景 假设我们有一个系统,用于跟踪和管理从…

作者头像 李华