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

题目描述

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

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

例如:

复制代码
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));
    }
}
相关推荐
qystca1 小时前
蓝桥云客--回文数组
算法
每次的天空1 小时前
Android学习总结之算法篇五(字符串)
android·学习·算法
Fantasydg1 小时前
DAY 37 leetcode 454--哈希表.四数相加
算法·leetcode·散列表
前端 贾公子2 小时前
LeetCode 2442:统计反转后的不同整数数量
算法·leetcode·职场和发展
lmy201211082 小时前
GESP:2025-3月等级8-T1-上学
c++·算法·图论·dijkstra
珊瑚里的鱼2 小时前
第五讲(下)| string类的模拟实现
开发语言·c++·笔记·程序人生·算法·visualstudio·visual studio
工一木子3 小时前
大厂算法面试 7 天冲刺:第6天-树与图深度剖析——高频算法面试题 & Java 实战
java·算法·面试
查理零世3 小时前
【蓝桥杯速成】日期问题(填空题) + 真题讲解 python
python·算法·蓝桥杯
杰克逊的日记3 小时前
大语言模型应用和训练(人工智能)
人工智能·算法·语言模型
振鹏Dong3 小时前
字符串——面试考察高频算法题
java·数据结构·算法