蓝桥杯官网填空题(梅森素数)

题目描述

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

如果一个数字的所有真因子之和等于自身,则称它为"完全数"或"完美数"

例如:

复制代码
6 = 1 + 2 + 3
28 = 1 + 2 + 4 + 7 + 14

早在公元前 300300 多年,欧几里得就给出了判定完全数的定理:

若 2n−1 是素数,则 2(n−1)∗(2n−1) 是完全数。

但人们很快发现,当 n 很大时,判定一个大数是否为素数到今天也依然是个难题。

因为法国数学家梅森的猜想,我们习惯上把形如:2n−1 的素数称为:梅森素数。

截止 2013 年 2 月,一共只找到了 48 个梅森素数。 新近找到的梅森素数太大,以至于难于用一般的编程思路窥其全貌,所以我们把任务的难度降低一点:

19631963 年,美国伊利诺伊大学为了纪念他们找到的第 23 个梅森素数 n=11213,在每个寄出的信封上都印上了"2的11213次方−1 是素数"的字样。

2的11213次方−1 这个数字已经很大(有 3000 多位),请你编程求出这个素数的十进制表示的最后 100 位。

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 128M
java 复制代码
import java.math.*;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        BigInteger b1=new BigInteger("2");
        BigInteger b2=new BigInteger("1");
        BigInteger b3=b1.pow(11213);
        BigInteger b4=b3.subtract(b2);
        String str=b4.toString();
        System.out.println(str.substring(str.length()-100));
    }
}
相关推荐
黎阳之光9 分钟前
全域实景立体管控:数字孪生与视频孪生技术体系白皮书
大数据·人工智能·算法·安全·数字孪生
88号技师1 小时前
2026年4月一区SCI-狒狒优化算法Baboon optimization algorithm-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
凯瑟琳.奥古斯特1 小时前
BFS解力扣1654最短跳跃次数
数据结构·算法·广度优先
sg_knight1 小时前
第一次用 OpenClaw,我让它 3 分钟写了个小工具
算法·llm·agent·ai编程·openclaw
m0_629494731 小时前
LeetCode 热题 100-----23.反转链表
数据结构·算法·leetcode·链表
炸膛坦客1 小时前
嵌入式 - 数据结构与算法:(1-10)排序算法 - 冒泡排序(Bubble Sort)
算法·排序算法
Hello eveybody1 小时前
介绍一下动态树LCT(Python)
开发语言·python·算法
不穿铠甲的穿山甲1 小时前
MMR最大边际相关性
算法
handler012 小时前
速通蓝桥杯省一:二分算法
c语言·开发语言·c++·笔记·算法·职场和发展·蓝桥杯
炽烈小老头2 小时前
【 每天学习一点算法 2026/05/08】最小覆盖子串
学习·算法