Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/25: Рейтинг темы: голосов - 25, средняя оценка - 4.96
1 / 1 / 0
Регистрация: 03.10.2013
Сообщений: 28

Проверка теоремы Гольдбаха

18.11.2013, 22:09. Показов 4888. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано четное число n>2; проверить для этого числа гипотезу Гольдбаха. Эта гипотеза (по сегодняшний день не опровергнута и полностью не доказана) заключается в том, что каждое четное n, больше двух, представляется в виде суммы двух простых чисел. (Определить процедуру, позволяющую распознать простые числа).

Необходимо написать программу с функцией, которая будет создавать массив из простых чисел, а затем программа будет выяснить принадлежит ли разность n и a[i] этому массиву. В конце выводить 2 простых числа из массива, из которых состоит n.

Я сделала блок-схему, но программу написать (правильно работающую) не могу



Добавлено через 35 минут
Думаю, что как-то так будет создаваться массив:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include <iomanip>
#include <math.h>
using namespace std;
 
int main()
#pragma massiv //Создает массив простых чисел
{setlocale(LC_ALL, "rus");  
 int i=3, j=1, k=2, n, l, a[1][1000];
 cout << "Введите ЧЕТНОЕ число n, которое СТРОГО БОЛЬШЕ, чем 2: " << endl; 
 cin >> n;
 if (i<n)
     (i=i+2);
     if (j<k)
         (j++);
         if (1%a[j]=0)
             (l=1);
         else (l=0) (k=k+1) (a[k]=i);
Дальше не получается, не знаю как цикл записать...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.11.2013, 22:09
Ответы с готовыми решениями:

Гипотеза Гольдбаха
Гипотеза Гольдбаха Гипотеза Гольдбаха—утверждение о том, что любое чётное число, начиная с 4, можно представить в виде суммы двух...

Гипотеза Гольдбаха
Составить программу для проверки гипотезы Гольдбаха о том, что каждое чётное число, большее 2, можно представить суммой двух простых ...

Гипотеза Гольдбаха
Гипотеза Гольдбаха заключается в том, что всякое четное число большее 2х можно представить в виде суммы двух простых чисел. По заданному...

7
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
18.11.2013, 22:45
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int a[1000];
for (k=3, i=0; i<1000; k+=2) {
  q = sqrt(k);
  for(j=3; j<=q; j+=2) if ((k%j)==0) break;
  if (j<=q) continue;
  a[i++] = k; // k - простое
}
// Ввод n
if (n==4) cout<<"2+2";
else if (n>a[999]) cout<<"Слишком большое n";
else {
   for(i=0; i<1000; i++) {
      b = n - a[i];
      for(j=0; j<1000; j++) if (b==a[j]) {
        cout << a[i] "+" b;
        break;
      }
      if (j<1000) break; 
   }
   if (i==1000) cout << "для " n " Гольдбах ошибся!";
}
}
Вот как-то так. Не проверял.
0
1 / 1 / 0
Регистрация: 03.10.2013
Сообщений: 28
18.11.2013, 23:08  [ТС]
Не удается запустить программу ...
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
18.11.2013, 23:12
Цитата Сообщение от Лель Посмотреть сообщение
Не удается запустить программу
То, что я написал - никакая не программа, это набросок, который вы сами уж доведите до ума...
0
1 / 1 / 0
Регистрация: 03.10.2013
Сообщений: 28
18.11.2013, 23:30  [ТС]
Я ее дополнила всем необходимым (как мне кажется, не знаю то я сделала или нет..), но выдает ошибки:
Ошибка 3 error C4700: использована неинициализированная локальная переменная "n" строка 19 символ 1
Предупреждение 2 warning C4244: =: преобразование "double" в "int", возможна потеря данных строка 13 символ 1

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include <iomanip>
#include <math.h>
using namespace std;
 
int main()
{setlocale(LC_ALL, "rus");  
int a[1000], q, k, j, i, b;
int n;
for (k=3, i=0; i<1000; k+=2) {
  q = sqrt(k);
  for(j=3; j<=q; j+=2) if ((k%j)==0) break;
  if (j<=q) continue;
  a[i++] = k; // k - простое
}
// Ввод n
if (n==4) cout<<"2+2";
else if (n>a[999]) cout<<"Слишком большое n";
else {
   for(i=0; i<1000; i++) {
      b = n - a[i];
      for(j=0; j<1000; j++) if (b==a[j]) {
        cout << a[i]<< "+"<< b;
        break;
      }
      if (j<1000) break; 
   }
   if (i==1000) cout << "для "<<n<< " Гольдбах ошибся!";
}
system ("pause");
    return 0; 
}
Добавлено через 9 минут
Как это исправить??
0
 Аватар для Folko
267 / 255 / 27
Регистрация: 27.09.2013
Сообщений: 876
Записей в блоге: 1
19.11.2013, 00:42
Лель, у вас n не имеет никакого значения. Думаю, проблема в этом. Его нужно ввести или задать в самой программе
0
419 / 418 / 167
Регистрация: 28.11.2010
Сообщений: 1,183
19.11.2013, 03:27
Цитата Сообщение от Лель Посмотреть сообщение
Я ее дополнила всем необходимым (как мне кажется, не знаю то я сделала или нет..), но выдает ошибки:
Ошибка 3 error C4700: использована неинициализированная локальная переменная "n" строка 19 символ 1
Предупреждение 2 warning C4244: =: преобразование "double" в "int", возможна потеря данных строка 13 символ 1

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include "stdafx.h"
#include <stdio.h>
#include <iostream>
#include <iomanip>
#include <math.h>
using namespace std;
 
int main()
{setlocale(LC_ALL, "rus");  
int a[1000], q, k, j, i, b;
int n;
for (k=3, i=0; i<1000; k+=2) {
  q = sqrt(k);
  for(j=3; j<=q; j+=2) if ((k%j)==0) break;
  if (j<=q) continue;
  a[i++] = k; // k - простое
}
// Ввод n
if (n==4) cout<<"2+2";
else if (n>a[999]) cout<<"Слишком большое n";
else {
   for(i=0; i<1000; i++) {
      b = n - a[i];
      for(j=0; j<1000; j++) if (b==a[j]) {
        cout << a[i]<< "+"<< b;
        break;
      }
      if (j<1000) break; 
   }
   if (i==1000) cout << "для "<<n<< " Гольдбах ошибся!";
}
system ("pause");
    return 0; 
}
Добавлено через 9 минут
Как это исправить??
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include <iostream>
#include <iomanip>
#include <cmath>
#include <cstdlib>
#include <ctime>
 
using namespace std;
 
long int * prime_arr(long int sz) {
    long int *a = new long int[sz];
    long int k = 2, i = 0, q = 0, j = 0;
    a[0]=2;
    for (k = 3, i = 1; i < 1000; k += 2) {
        q = sqrt(k);
        //cout << ", "<<q << " ";
        for (j = 3; j <= q; j += 2)
            if ((k % j) == 0)
                break;
        if (j <= q)
            continue;
        a[i++] = k; // k - простое
    }
    return a;
 
}
 
void check(long int n, long int *a, long int sz) {
    long int i, j, b;
    for (i = 0; i < sz; i++) {
        b = n - a[i];
        for (j = 0; j < sz; j++)
            if (b == a[j]) {
                cout << a[i] << "+" << b;
                break;
            }
        if (j < sz)
            break;
    }
    if (i == sz)
        cout << "для " << n << " Гольдбах ошибся!";
}
 
int main() {
    setlocale(LC_ALL, "rus");
    srand(time(NULL));
    long int i = 0;
    long int n = 0;
    long int sz = 10000;
    long int *a =prime_arr(sz);
    for (int i = 0; i < sz; ++i)
        cout << setw(4) << a[i];
    while (++i <= 10) {
        cout << "\npass " << i << endl;
        n = rand() % (sz + 1);
        n = n%2==0? n: n+1;
        cout << n << "= ";
        check(n, a, sz);
    }
    delete[] a;
    return 0;
}
0
0 / 0 / 0
Регистрация: 05.04.2023
Сообщений: 2
05.04.2023, 11:48
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#include <iostream>
#include <vector>
bool prime(int n);
using namespace std;
int main()
{
    system("chcp 1251");
    
    int nums;
    cout << "Введите конечное число последовательности: ";
    cin >> nums;
 
    //находим все простые числа до nums и сохраняем их в массив
    vector<int> simple_nums;
    for (int i = 1; i < nums; i++)
    {   
        //если число простое, добавляем его в массив простых чисел
        if (prime(i)) {
            simple_nums.push_back(i);
        }
    }
 
    
 
    //проходим по всем четным числам до nums начиная с 4 по теории гольбаха
    for (int i = 2; i < nums; i++)
    {
        //находим последовательность всех четных чисел
        if (i % 2 == 0) {
            //перебираем значения в массиве nums
            for (int n : simple_nums) {
                for (int k : simple_nums) {
                    //если эти простые числа в сумме дают само число(внешнего числа, это четное число больше 4) 
                    if (n + k == i) {
                        //выводим доказательство суммы простых чисел на равенство четному числу.
                        cout <<n<<"+"<<k<<"="<<i << endl;
                    }
                }
            }
        }
    }
}
//функция опредения является ли число простым
bool prime(int n) {
    //идем от 2 до корня из введенного числа
    for (int i = 2; i <= sqrt(n); i++) {
        //если число переданное в аргумент функции без остатка делится на число в последовательно это значит, что число не простое, вернем false
        if (n % i == 0)
            return false;
    }
    //после проверки, результатом не послужил false, следовательно не было выхода из программы, то мы вернем true можно сказать, что число простое.
    return true;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.04.2023, 11:48
Помогаю со студенческими работами здесь

Составить алгоритм проверки гипотезы Гольдбаха
Составить алгоритм проверки гипотезы Гольдбаха о представлении каждого чётного числа n(n&gt;2) в виде суммы двух простых чисел.Использовать...

Проверить для данного числа гипотезу Гольдбаха
Дано чётное число n&gt;2; проверить для этого числа гипотезу Гольдбаха. Эта гипотеза заключается в том, что каждое чётное n, больше двух,...

Проверить для заданного числа Гипотезу Гольдбаха
Заданное четное число n&gt; 2. Проверить для этого числа гипотезу Гольбаха: каждое четное n&gt; 2 можно представить в виде суммы двух простых...

Проверить гипотезу Гольдбаха для заданного четного числа
Дано четное число n&gt;2; проверить для этого числа гипотезу Гольдбаха. Эта гипотенуза заключается в том, что каждое четное число n, большее...

Утверждение Гольдбаха для чисел не превышающих число 100
//145. Один из первых академиков российской Академии наук(1725 гг.) математик Христиан Гольдбах(1690–1764 гг.) //выдвинул так называемую...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru