返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >c++梅森数问题怎么解决
  • 646
分享到

c++梅森数问题怎么解决

2023-07-04 21:07:17 646人浏览 独家记忆
摘要

今天小编给大家分享一下c++梅森数问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。题目:要求:按从小到大的顺序输出

今天小编给大家分享一下c++梅森数问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

题目:

要求:按从小到大的顺序输出所有不超过2……n−1的梅森数,每行一个。如果完全没有,则输出“None”。

别人的例子

#include <math.h>int main() {    int n = 0, m = 0,  e = 0,h=0;    int i = 0;    scanf("%d", &n);    int a = (int)pow(2, n) - 1;//最大数    for (i = 2; i < a; i++) {//数字挨个增加        m = 0;        for (e = 2; e <= sqrt(i); e++) {//判断是不是为素数            if (i % e == 0) {                m++;                break;            }        }        if (m == 0) {            for (e = 1; e < n; e++) {                if (2.0 == pow(i + 1, 1.0 / (1.0 * e))) {//判断是否满足另一个条件                    printf("%d\n", i);                    h++;                    break;                }            }        }    }    if (h == 0) {        printf("None");    }    return 0;}

发现报错: 分析错误: 我感觉可能是求梅森数的思路不对。

for循环里的i是否需要在循环外声明。

判断i是否为素数的方式可以改为使用线性筛法。

在判断梅森数时,使用pow函数求2的幂次方会影响精度,建议使用位运算进行优化

如果完全没有梅森数,应该在循环外输出“None”。

我的代码

    #include <stdio.h> #include <math.h>  int main() {  int n = 0, p = 0, flag = 0;  scanf("%d", &n);  for (p = 2; p <n; p++) {  int i = 2, m = 2; //m为当前计算出的2^p-1的值  //线性筛法求2^p-1是否为素数  while (i <= sqrt(m)) {  if (m % i == 0) {  break; //不是素数,跳出循环  }  i++;  }  //如果i>sqrt(m)说明m是素数  if (i > sqrt(m)) {  printf("%d\n", m);  flag = 1; //标记是否有梅森数  }  m = (m << 1) + 1; //计算下一个2^p-1的值  }  if (!flag) {  printf("None");  }  return 0;  }

显示部分正确修改过的代码

#include <iOStream>#include <cmath>using namespace std;int main(){int n;cin >> n;bool flag = false; // 记录是否有梅森数for (int i = 2; i < n; i++){    bool isPrime = true; // 记录i是否为素数    for (int j = 2; j <= sqrt(i); j++)    {        if (i % j == 0)        {            isPrime = false;            break;        }    }    if (isPrime) // 如果i为素数    {        int m = i; // 记录i的值        int sum = 0; // 记录i的位数和        while (m > 0)        {            sum += m % 10;            m /= 10;        }        if (sum == i) // 如果i的位数和等于i本身,则为梅森数        {            cout << i << endl;            flag = true; // 有梅森数        }    }}if (!flag) // 如果没有梅森数{    cout << "None" << endl;}return 0;}

以上就是“c++梅森数问题怎么解决”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网其他教程频道。

--结束END--

本文标题: c++梅森数问题怎么解决

本文链接: https://lsjlt.com/news/347684.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • c++梅森数问题怎么解决
    今天小编给大家分享一下c++梅森数问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。题目:要求:按从小到大的顺序输出...
    99+
    2023-07-04
  • c++梅森数源码示例解析
    目录题目:别人的例子我的代码显示部分正确修改过的代码题目: 要求:按从小到大的顺序输出所有不超过2……n−1的梅森数,每行一个。如果完全没有...
    99+
    2022-12-29
    c++ 梅森数 c++ 梅森数源码解析
  • C++素数环问题怎么解决
    C++素数环问题可以通过回溯算法来解决。以下是一种解决方案的示例代码:c++#include #include using name...
    99+
    2023-10-20
    C++
  • 怎么解决C++多数元素问题
    本篇内容介绍了“怎么解决C++多数元素问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 题目描述给定一个大小为 n ...
    99+
    2023-06-03
  • c++水仙花数问题怎么解决
    水仙花数是指一个n位数,其各位数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153...
    99+
    2024-03-07
    c++
  • c语言怎么解决素数环问题
    素数环问题是指在一个圆环上排列一组互不相同的素数,使得任意两个相邻的素数之和也是素数。解决素数环问题的一种方法是使用回溯法。以下是一...
    99+
    2023-08-08
    c语言
  • C语言怎么解决Fibonacci数列问题
    在C语言中,可以使用循环或递归的方式来解决Fibonacci数列问题。 使用循环解决Fibonacci数列问题: #includ...
    99+
    2024-02-29
    C语言
  • C#中InvalidateRect问题怎么解决
    在C#中,InvalidateRect是用于无效化指定矩形区域的方法。当需要重新绘制该区域时,可以调用该方法。如果在使用Invali...
    99+
    2023-09-11
    C#
  • C语言轮转数组问题怎么解决
    今天小编给大家分享一下C语言轮转数组问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。题目描述给你一个数组,将数组中...
    99+
    2023-06-29
  • C语言怎么解决轮转数组问题
    本篇内容主要讲解“C语言怎么解决轮转数组问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言怎么解决轮转数组问题”吧!题目1.题目描述给你一个数组,将数组中的元素向右轮转 k 个位...
    99+
    2023-06-30
  • C++数据结构背包问题怎么解决
    在C++中,可以使用数组或者链表来实现背包问题的解决。 首先,定义一个结构体或者类来表示物品,包括物品的重量和价值等信息。 然后,定...
    99+
    2023-10-24
    C++
  • 怎么解决mysql c乱码问题
    这篇文章主要讲解了“怎么解决mysql c乱码问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决mysql c乱码问题”吧! ...
    99+
    2024-04-02
  • C++怎么解决格雷码问题
    今天小编给大家分享一下C++怎么解决格雷码问题的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。格雷码For example, ...
    99+
    2023-06-19
  • C#中的CRITICAL_SECTION问题怎么解决
    在 C# 中,没有直接的类似于 C++ 中的 CRITICAL_SECTION 的同步原语。不过,你可以使用 Monitor 类来实...
    99+
    2023-09-26
    C#
  • c++ error:crosses initialization of问题怎么解决
    今天小编给大家分享一下c++ error:crosses initialization of问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望...
    99+
    2023-07-05
  • c++ undefined reference to问题怎么解决
    在C++中,"undefined reference"错误通常是由以下原因引起的: 函数或变量的定义缺失:在使用某个函数或变量之...
    99+
    2023-10-28
    c++
  • C语言怎么解决无重复数字问题
    这篇文章主要介绍了C语言怎么解决无重复数字问题的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言怎么解决无重复数字问题文章都会有所收获,下面我们一起来看看吧。题目:有1、2、3、4个数字,能组成多少个互不相同...
    99+
    2023-06-17
  • C#中MeasureString参数不准确问题怎么解决
    在C#中,当使用`Graphics.MeasureString`方法测量字符串时,可能会出现参数不准确的问题。这可能是因为测量的字符...
    99+
    2023-08-08
    C# MeasureString
  • C语言数学问题与简单DP背包问题怎么解决
    本篇内容介绍了“C语言数学问题与简单DP背包问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!数学顾名思义,数学类的题就是都可以用数...
    99+
    2023-06-30
  • C#垃圾回收问题怎么解决
    本篇内容主要讲解“C#垃圾回收问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#垃圾回收问题怎么解决”吧!这里涉及到C#垃圾回收的问题:C#垃圾回收是.NET运行库的一部分。垃圾回收...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作