Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Даны три действительных числа, выбрать (вывести на экран) те из них, которые пренадлежат интервалу http://www.cyberforum.ru/cpp-beginners/thread1011323.html
Задание такое: Даны три действительных числа, выбрать (вывести на экран) те из них, которые пренадлежат интервалу (4,7)... При написании кода использовать указатели и функцию возвращающую более...
C++ выполняющий обработку сообщений передаваемых по сети на visual c++ 2010 Здравствуйте помогите мне с таким вопросом можно ли создать выполняющий обработку сообщений передаваемых по сети на visual c++ 2010!!!!! http://www.cyberforum.ru/cpp-beginners/thread1011309.html
C++ Простое выражение
Есть выражение M=b*((a^x)^-1) mod p Значения M,b,a,p,x известны. Посчитает ли компилятор это выражение в лоб? У меня M постоянно равняется 0, я разные значения подставлял и всеравно 0. Или эту...
Подскажите где ошибка C++
Напишите программу для преобразования футов в дюймы. Организуйте ввод числа футов и вывод на экран соответствующего числа дюймов. Повторяйте эту процедуру до тех пор, пока пользователь не введет 0...
C++ Поменять местами элементы матрицы http://www.cyberforum.ru/cpp-beginners/thread1011304.html
Как поменять местами минимальный элемент массива А(57) и матрицы В(7*5)
C++ Разделить элементы каждого столбца заданной матрицы на последний элемент столбца Разделить элементы каждого столбца заданной матрицы на последний элемент столбца. подробнее

Показать сообщение отдельно
vua72
416 / 416 / 85
Регистрация: 28.11.2010
Сообщений: 1,183
Завершенные тесты: 1
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
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru