题目描述

形如2P−12^{P}-12P−1 的素数称为麦森数,这时PPP 一定也是个素数。但反过来不一定,即如果PPP 是个素数,2P−12^{P}-12P−1 不一定也是素数。到1998年底,人们已找到了37个麦森数。最大的一个是P=3021377P=3021377P=3021377 ,它有909526位。麦森数有许多重要应用,它与完全数密切相关。

任务:从文件中输入PPP (1000<P<31000001000<P<31000001000<P<3100000 ),计算2P−12^{P}-12P−1 的位数和最后500位数字(用十进制高精度数表示)
输入输出格式
输入格式: 文件中只包含一个整数PPP (1000<P<31000001000<P<31000001000<P<3100000 ) 输出格式: 第一行:十进制高精度数2P−12^{P}-12P−1 的位数。 第2-11行:十进制高精度数2P−12^{P}-12P−1 的最后500位数字。(每行输出50位,共输出10行,不足500位时高位补0) 不必验证2P−12^{P}-12P−1 与P 是否为素数。

高精+快速幂

#include<cstdio>
#include<math.h>
#include<string.h>
#include<iostream>
using namespace std;
int P;
double n;
int a[110000],ans[110000];
void read(int &x) //快读
{
int f=1;
char t=getchar();
x=0;
while((t<48)or(t>57))
{
if(t=='-')f=-1;
t=getchar();
}
while((t>=48)and(t<=57))
{
x=x*10+t-48;
t=getchar();
}
x*=f;
}
void jian(int a[])
{
a[1]-=1;
for (int i=1; i<=a[0]; ++i)
{
if (a[i]<0)
{
a[i]+=10;
--a[i+1];
}
else break;
}
}
void cheng(int a[])
{
int len=a[0]+1;
int c[510];
memset(c,0,sizeof(c));
for (int i=1; i<=a[0]; ++i)
{
int t=0;
c[i]=c[i]+t+a[i]*2;
t=c[i]/10;
c[i]%=10;
c[i+1]=t;
}
while ((c[len]==0) && (len>1)) --len;
for (int i=1; i<=len; ++i) a[i]=c[i];
a[0]=len;
}
void cheng1(int a[],int b[])
{
int c[110000];
memset(c,0,sizeof(c));
int n=min(a[0],500),m=min(b[0],500),len=n+m;
for (int i=1; i<=n; ++i)
{
int t=0;
for (int j=1; j<=m; ++j)
{
c[i+j-1]=c[i+j-1]+t+a[i]*b[j];
t=c[i+j-1]/10;
c[i+j-1]%=10;
}
c[i+m]=t;
}
while ((c[len]==0) && (len>1)) --len;
for (int i=1; i<=len; ++i) a[i]=c[i];
a[0]=len;
}
int main()
{
//freopen("mason.in","r",stdin);
//freopen("mason.out","w",stdout);
read(P);
n=(double)P*(double)(log(2)/log(10));//直接算位数
n+=1;
printf("%d",(int)n);
a[1]=2;
a[0]=1;
ans[1]=1;
ans[0]=1;
for (; P; P>>=1,cheng1(a,a)) //p>>=1 等于 p /= 2,cheng1(a,a)为预处理,为cheng1(ans,a)做准备
if (P&1) cheng1(ans,a); //是奇数还要再乘一个
jian(ans);
for (int i=500; i>=1; --i)
{
if (i%50==0) printf("\n");
printf("%d",ans[i]);
}
return 0;
}

麦森数--NOIP2003的更多相关文章

  1. [NOIP2003普及组]麦森数(快速幂+高精度)

    [NOIP2003普及组]麦森数(快速幂+高精度) Description 形如2^P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P-1不一定也是素数.到1998 ...

  2. 【转】[NOIP2003普及组]麦森数

    来源:http://vivid.name/tech/mason.html 不得不纪念一下这道题,因为我今天一整天的时间都花到这道题上了.因为这道题,我学会了快速幂,学会了高精度乘高精度,学会了静态查错 ...

  3. 【高精度乘法】NOIP2003麦森数

    题目描述 形如2^{P}-12P−1的素数称为麦森数,这时PP一定也是个素数.但反过来不一定,即如果PP是个素数,2^{P}-12P−1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的 ...

  4. P1045 [NOIP2003 普及组] 麦森数

    题目描述 形如2^P−1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P−1不一定也是素数. 到1998年底,人们已找到了37个麦森数.最大的一个是P=3021377, ...

  5. 洛谷试炼场-简单数学问题-P1045 麦森数-高精度快速幂

    洛谷试炼场-简单数学问题 B--P1045 麦森数 Description 形如2^P−1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果PP是个素数,2^P-1 不一定也是素数.到19 ...

  6. NOIP200304麦森数

    试题描述 形如2P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2P-1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=3021377,它有9 ...

  7. vijosP1223麦森数

    vijosP1223麦森数 链接:https://vijos.org/p/1223 [思路] 快速幂+高精乘. 计算2^p-1可以快速幂的方法在O(logn)的时间内出解,限于数据范围我们需要用到高精 ...

  8. TZOJ 4839 麦森数(模拟快速幂)

    描述 形如2^P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^P-1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=3021377,它有9 ...

  9. 洛谷 P1045 麦森数

    题目描述 形如2^{P}-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2^{P}-1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=30213 ...

随机推荐

  1. jQuery导航插件One-Page-Nav演示-显示命名锚记

    jQuery导航插件One-Page-Nav演示-显示命名锚记 简介 使用 选项 示例 推荐 简介 电商网站的分类比较明确,比如1楼是手机通讯产品,2楼是家用电器,3楼是服装鞋包等等,旁边还会有一个固 ...

  2. CSS——行内元素的margin与padding

    行内元素: 1.margin:0 20px:只可以定义左右. 2.pading:20px 20px 20px 20px:上下左右都有效 例如span: <!DOCTYPE html> &l ...

  3. dubbo之优雅停机

    优雅停机 Dubbo 是通过 JDK 的 ShutdownHook 来完成优雅停机的,所以如果用户使用 kill -9 PID 等强制关闭指令,是不会执行优雅停机的,只有通过 kill PID 时,才 ...

  4. http通信流程

    Host https://www.charlesproxy.com Path / Notes SSL Proxying not enabled for this host. Enable in the ...

  5. Review:Microbiota, metagenome, microbiome傻傻分不清

    Microbiota 微生物群   微生物群是指研究动植物体上共生或病理的微生物生态群体.微生物群包括细菌.古菌.原生动物.真菌和病毒.研究表明其在宿主的免疫.代谢和激素等方面非常重要.近义词Micr ...

  6. cocos creator destroy方法

    node.destroy(),Node.destroyAllChildren并不会立即销毁,实际销毁操作会延迟到当前帧渲染前执行. 这段话可能不明白,但是在Node.destroyAllChildre ...

  7. NGINX+PHP-FPM7 FastCGI sent in stderr: “Primary script unknown”

    https://www.cnblogs.com/hjqjk/p/5651275.html 一开始是Nginx打开网页显示一直是拒绝访问.查看nginx日志是报错显示我的题目,然后就各种搜索解决啊! 百 ...

  8. javaWEB中web.xml配置文件相关

    1.常用节点的执行顺序: context-param -> listenter -> filter -> servlet -> interceptor,其中有多个filter的 ...

  9. VMware Workstation 15 安装教程

    注:操作系统必须是64位    软件:360软件管家获取 1.运行下载完成的Vmware Workstation虚拟机软件包. 虚拟机软件的安装向导初始界面 2.在虚拟机软件的安装向导界面单击“下一步 ...

  10. HTML学习笔记之标签基础

    目录 1.基本标签 2.链接 3.图像 4.表格 5.列表 6.块与布局 1.基本标签 (1)标题与段落 标签 <h1> ~ <h6> 分别用于定义一至六级标题,标签 < ...