| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> JOE的算数(快速幂算法实现) -> 正文阅读 |
|
[C++知识库]JOE的算数(快速幂算法实现) |
资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 有一天,JOE终于不能忍受计算a^b%c这种平凡的运算了。所以他决定要求你写一个程序,计算a^b%c。 输入格式 三个非负整数a,b,c; 输出格式 一个整数ans,表示a^b%c; 样例输入 7 2 5 样例输出 4 数据规模和约定 30% a <= 100, b <= 10^4, 1 <= c <= 100 思路:用快速幂算法实现,结合数学公式(a*b)%c=(a%c*b%c)%c,所以,a与b的乘积再取模,可以拆开,其中a与b还可以看为1,则a%c=a%c%c(b%c=b%c%c).快速幂算法:由于指数爆炸,当指数足够大时会溢出,尽管是long long的范围也会溢出,而且还会增加循环的次数,比如2的100次方,需循环100次,而2得100次方写成4^50=16^25=256^12*16。(n为奇数时,拆成上一次的底数*扩大的底数的偶次方) 经过更少的循环,让指数不断除以2,而底数扩大为自身的平方,最后,指数n变为1,将扩大后累计的底数赋值给输出结果,最后退出循环。(如下所示) 由于位操作更快,得以终极优化。 n&1 (n%2==1) n>>1(n/=2) n<<1(n*=2)
|
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 7:19:12- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |