洛谷P1045 麦森数。 快速幂算法以及固定位数的高精度乘法的优化
P1045 [NOIP2003 普及组] 麦森数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

想法很简单,我们要做的就是两件事,求2^P-1的位数,求出2^P-1的最后500位数,也就是低五百位,500位想一想常规类型肯定存不下,int到10^9,long long 到10^18,于是只能用高精度乘法来算阶乘
- 第一步,可以不用通过求出所有2^P-1的数然后记录位数来得出其位数,给出几个例子
1000为四位数,位数=lg1000+1=3+1=4,同理对于5486,位数=int(lg5486)+1=4,所以对于一个数,只需要求他对10的对数值加上1就是其位数,对于这次的2^P-1,可以知道其尾数必为2的倍数,(0除外),因此2^P-1的位数即2^P的位数
于是其位数=int(lg(2^P))+1=int(P*lg2)+1,这样看来只需要调用cmath头文件里的lg10函数求出lg2就可以直接得出位数
2. 第二步,求出其后500位, 这里应用高精度乘法,但是由于只需要求500位,高于500位的数字其实并不用去关注,直接丢掉即可
const int MAX = 500;
typedef long long LL;//不用long long会爆掉的
void Big_Mul(LL* ans, LL* Base)
{
LL C[MAX] = { 0 };
for (int i = 0; i < MAX; i++)
{
for (int j = 0; j < MAX; j++)
{
if(i+j<MAX)//高于500位直接舍弃
C[i + j] += ans[i] * Base[j];
}
}
//下面是逐个位进位处理
//方便起见我们不设置进制位,而是让后一位数加上前一位数的进位值,然后前一位数舍弃其进位值来实现逐位进位
for (int i = 0; i <MAX-1; i++)
{
C[i + 1] = C[i + 1] + C[i]/10;
C[i] %= 10;//舍弃进位值
}
C[MAX - 1] %= 10;//舍弃最大为的进位值,因为只需要后五百位,多的位数不需要
for (int i = 0; i < MAX; i++)
ans[i] = C[i];//拷贝
}
只有高精度乘法,然后朴素乘方的话会TLE的,因此还要配合快速幂来加速
下面给出完整代码
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
const int MAX = 500;
typedef long long LL;
void Big_Mul(LL* ans, LL* Base)
{
LL C[MAX] = { 0 };
for (int i = 0; i < MAX; i++)
{
for (int j = 0; j < MAX; j++)
{
if(i+j<MAX)
C[i + j] += ans[i] * Base[j];
}
}
for (int i = 0; i <MAX-1; i++)
{
C[i + 1] = C[i + 1] + C[i]/10;
C[i] %= 10;
}
C[MAX - 1] %= 10;
for (int i = 0; i < MAX; i++)
ans[i] = C[i];
}
int main()
{
int p;
cin >> p;
cout << int(log10(2.0) * p +1)<< endl;//求出位数并输出
LL ans[MAX] = { 0 };
LL Base[MAX] = { 0 };//高精度数组初始化
ans[0] = 1;//结果存储
Base[0] = 2;//基数也就是底数
while (p)//快速幂
{
if (p & 1)
Big_Mul(ans, Base);
Big_Mul(Base, Base);//可以看到就是将快速幂里的乘法变为了高精度乘法
p >>= 1;
}
ans[0]--;//求出2^P-1
for (int i = 499; i >= 0; i--)//逆序输出500位
{
cout << ans[i];
if(i%50==0)//每50位换行
cout << endl;
}
return 0;
}
洛谷P1045 麦森数。 快速幂算法以及固定位数的高精度乘法的优化的更多相关文章
- 洛谷 P1045 麦森数
题目描述 形如2^{P}-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^{P}-1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=30213 ...
- 洛谷P1045 麦森数
题目描述 形如2^{P}-12 P −1的素数称为麦森数,这时PP一定也是个素数.但反过来不一定,即如果PP是个素数,2^{P}-12 P −1不一定也是素数.到1998年底,人们已找 ...
- NOIP2003 普及组 洛谷P1045 麦森数 (快速幂+高精度)
有两个问题:求位数和求后500位的数. 求位数:最后减去1对答案的位数是不影响的,就是求2p的位数,直接有公式log10(2)*p+1; 求后500位的数:容易想到快速幂和高精度: 1 #includ ...
- 洛谷 P1045 麦森数 (快速幂+高精度+算位数骚操作)
这道题太精彩了! 我一开始想直接一波暴力算,然后叫上去只有50分,50分超时 然后我改成万位制提高运算效率,还是只有50分 然后我丧心病狂开long long用10的10次方作为一位,也就是100亿进 ...
- P1045麦森数
P1045麦森数 #include<iostream> #include <cmath> #include <cstring> const int maxn = 1 ...
- 洛谷 P1226 【模板】快速幂||取余运算
题目链接 https://www.luogu.org/problemnew/show/P1226 题目描述 输入b,p,k的值,求b^p mod k的值.其中b,p,k*k为长整型数. 输入输出格式 ...
- 洛谷试炼场-简单数学问题-P1045 麦森数-高精度快速幂
洛谷试炼场-简单数学问题 B--P1045 麦森数 Description 形如2^P−1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果PP是个素数,2^P-1 不一定也是素数.到19 ...
- 【题解】[P1045] 麦森数
题目 题目描述 形如2^P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P-1 不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=30213 ...
- 洛谷P1226 【模板】快速幂||取余运算
题目描述 输入b,p,k的值,求b^p mod k的值.其中b,p,k*k为长整型数. 输入输出格式 输入格式: 三个整数b,p,k. 输出格式: 输出“b^p mod k=s” s为运算结果 S1: ...
- 洛谷P1313 计算系数【快速幂+dp】
P1313 计算系数 题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别 ...
随机推荐
- 实战指南 | Serverless 架构下的应用开发
作者 | 刘宇.田初东.卢萌凯.王仁达 UC Berkeley认为Serverless架构的出现过程类似于40多年前从汇编语言转向高级语言的过程,在未来Serverless架构的使用会飙升,或许服务器 ...
- kafka搭建 一、单机版
系列导航 一.kafka搭建-单机版 二.kafka搭建-集群搭建 三.kafka集群增加密码验证 四.kafka集群权限增加ACL 五.kafka集群__consumer_offsets副本数修改 ...
- 从零开始制作PyTorch的Singularity容器镜像
技术背景 在前面的博客中,我们大篇幅的使用到了Docker和Singularity这两种常见的容器化编程环境解决方案,使得我们的各个编程环境能够更好的隔离.如果要展开讲解容器化编程环境的重要性的话,我 ...
- SV 接口
概述 接口 main bus有很多信号线 verilog会先将模块的输出信号拉出来,然后再将其连接到其他模块,进行不同模块之间的连接比较麻烦且容易出错 interface - 将端口封装到接口中 接口 ...
- 【Linux API 揭秘】module_init与module_exit
[Linux API 揭秘]module_init与module_exit Linux Version:6.6 Author:Donge Github:linux-api-insides 1.函数作用 ...
- Mybatis @Insert插入数据返回自增的主键id
mapper层 @Insert("insert into t_user (username,password,valid,create_time) values (#{username},# ...
- Data truncated for column '字段名' at row 1 的解决方法
1.原因: 修改表结构 XXX 为 not null 时,表数据 XXX 字 段 存在 null 值. 2.解决: 去掉或修改 带有 null 值 的 ( 需要设置 not null 的) 字段
- [转帖]Linux的tmpfs和ramfs
tmpfs tmpfs是一种虚拟内存文件系统, 它的存储空间在VM里面,现在大多数操作系统都采用了虚拟内存管理机制, VM(Virtual Memory) 是由Linux内核里面的VM子系统管理. V ...
- [转帖]详解:Linux Chrony 设置服务器集群同步时间
https://www.linuxprobe.com/centos7-chrony-time.html 导读 Chrony是一个开源的自由软件,像CentOS 7或基于RHEL 7操作系统,已经是默认 ...
- [转帖]dd - Linux世界中的搬运工
<存储工具系列文章>主要介绍存储相关的测试和调试工具,包括不限于dd.fio.vdbench.iozone.iometer.cosbench等性能负载工具,及strace等调试工具. dd ...