RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 798038
Accepted
Alex
Alex
Asked:2020-03-14 17:50:59 +0000 UTC2020-03-14 17:50:59 +0000 UTC 2020-03-14 17:50:59 +0000 UTC

打印两个数之和,这将是一个素数

  • 772

有一个从 1 到 500 的数组。在其中,您需要将数字分成对,以便这些数字的总和是质数。在它显示正确的前3个数字之后,其余的都是不可理解的(太大,即不等于简单的数字)。

#include "stdafx.h"
#include <iostream> 
#include <cmath>
using namespace std;   
void amount(int array[], int &lenAr);    
int main(void)
{
    setlocale(LC_ALL, "Russian");
    int a, length_array; 
    length_array = 500; 
    int *arr = new int[length_array];
    a = 1;    
    for (int i = 0; i < 500; i++) { 
        arr[i] = a + i;
    }
        amount(arr, length_array); 
        system("pause"); 
        return 0;
}

void amount(int array[], int &lenAr)
{
    int *result = new int[500]; 
    int n, i; 
    int alpha, delta; 
    bool isPrime = true;                            
    for (int r = 0; r < 500; r++) {
        alpha = r;
        delta = alpha + 1;
        n = array[alpha] + array[delta];
        for (i = 2; i <= (sqrt(abs(n))); i++) {
            if (n%i == 0) {
                isPrime = false;
            }
        }
        if (isPrime) {
            result[r] = n;
        }
    }
    cout << "Все числа" << endl;
    for (int counter = 0; counter < lenAr; counter++)
    {
        cout << array[counter] << "  ";
    }
    cout << endl << "Простые числа" << endl;
    for (int counter = 0; counter < 30; counter++)
    {
        cout << result[counter] << "  ";
    }
    cout << endl;
    delete[] array;
    delete[] result;
}
c++
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Anton Shchyrov
    2020-03-14T18:08:10Z2020-03-14T18:08:10Z

    所有错误都在这里

    bool isPrime = true;                            
    for (int r = 0; r < 500; r++) {  // 1
        alpha = r;
        delta = alpha + 1;           // 2
        n = array[alpha] + array[delta];
        for (i = 2; i <= (sqrt(abs(n))); i++) {
            if (n%i == 0) {
                isPrime = false;  // 3
            }
        }
        if (isPrime) {
            result[r] = n;  // 4
        }
    }
    ..........
    delete[] array;  // 5
    
    1. 您正在传递数组的长度,但您正在运行高达 500 的循环
    2. 您将 1 添加到当前索引。alpha == 499 delta == 500越界数组时
    3. 如果你已经发现这个数是合数,为什么还要继续循环呢?
    4. 只有当它是素数时,才将数字写入result数组。在这种情况下,按第一个数字的索引写下来。因此,数组中的一堆元素result未初始化并包含垃圾。你看这个垃圾
    5. 释放您未分配的内存是非常糟糕的做法。

    这是或多或少经过修饰的代码

    #include <vector>
    #include <iostream> 
    #include <cmath>
    using namespace std;
    
    void amount(int array[], int lenAr);
    
    int main(void) {
      setlocale(LC_ALL, "Russian");
      int a, length_array;
      length_array = 500;
      int * arr = new int[length_array];
      for (int i = 1; i <= length_array; i++) {
        arr[i] = i;
      }
      amount(arr, length_array);
      delete[] arr;
      system("pause");
      return 0;
    }
    
    bool isPrime(int val) {
      int middle = (int)sqrt(val);
      for (int i = 2; i <= middle; i++) {
        if (val % i == 0)
          return false;
      }
      return true;
    }
    
    void amount(int array[], int lenAr) {
      vector<int> res = new int[lenAr];
      for (int i = 0; i < lenAr - 1; i++) {
        for (int j = i + 1; j < lenAr; j++) {
          int n = array[i] + array[j];
          if (isPrime(n)) {
            res.push_back(n);
          }
        }
      }
    
      cout << "Все числа" << endl;
      for (int i = 0; i < lenAr; i++) {
        cout << array[i] << "  ";
      }
    
      cout << endl << "Простые числа" << endl;
      for (int i = 0; i < res.size(); i++) {
        cout << res[i] << "  ";
      }
    
      cout << endl;
    }
    
    • 3

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5