1 / 1 / 0
Регистрация: 04.02.2014
Сообщений: 45
1

Поиск простых чисел

20.10.2014, 23:32. Показов 2040. Ответов 25
Метки нет (Все метки)

необходимо найти все простые числа от 1 до 100. Вот я написал код:
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
#include <iostream>
#include <string>
#include <cstdlib>
#include "stdafx.h"
 
int main() {
    double ost;
    vector <int> m();
    int b=0,c,n;
    for(int i=0,i<100,i++) {
        while(b<i) {
            c=i%b;
            b++;
            if(c==0) {
                n++;
            }
                    }
            if(n==2) {
                i=m.push_back;
            }
    }
    int z;
    while(z<size.m){
        z++;
        cout<<vector m(z);
    }
}
Но не совсем понял операции производимые с вектором. Подскажите, правильно ли я вообще написал код?
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.10.2014, 23:32
Ответы с готовыми решениями:

Поиск простых чисел
#include &lt;iostream&gt; #include &lt;stdio.h&gt; #include &lt;locale.h&gt; using namespace std; int y;...

Поиск простых чисел
хочу написать программу по поиску простых чисел вот что у меня есть #include &lt;iostream&gt;...

Поиск простых чисел
Почему мне возвращает просто непарные числа? в чем загвоздка #include &lt;iostream&gt; bool...

Поиск простых чисел
3. Разработать программу поиска простых чисел в отрезке (1..N) целых положительных чисел. Программа...

25
Байт
22.10.2014, 20:25     Поиск простых чисел
  #21

Не по теме:

Цитата Сообщение от ValeryS Посмотреть сообщение
это современный? к своему стыду не помню имен
Григорий. Однако Яковлевич.
Да хоть оба! Хоть 100 перельманов вместе с Пуанкаре! Не хочет понимать - так и не поймет!:)

0
ValeryS
22.10.2014, 20:27
  #22

Не по теме:

Цитата Сообщение от Байт Посмотреть сообщение
Григорий. Однако Яковлевич.
т.е сын=-O
или просто тезка

0
Байт
22.10.2014, 20:34
  #23

Не по теме:

Цитата Сообщение от ValeryS Посмотреть сообщение
или просто тезка
Просто тезка. У евреев Яковов, как у русских - Иванов, как у турков - Али. А в переводе - Пятка. Второй близнец. Вылез по пятам за братишкой Исавом. Однако, Исав был голоден и продал свое первородство за тарелку чечевичной похлебки. Я пробовал - вкусно!:)

0
5488 / 4883 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
22.10.2014, 20:38 24
Конкурс(поиск простых чисел)
0
ValeryS
22.10.2014, 20:42
  #25

Не по теме:

Цитата Сообщение от Байт Посмотреть сообщение
А в переводе - Пятка.
я когда ребенка из роддома встречал, то изучал стенд с именами
и там было вроде Яков "любимец Бога" или "славит Бога" не помню точно, но слово Бог звучало
Цитата Сообщение от Байт Посмотреть сообщение
Я пробовал - вкусно
Верю на слово, хотя лично я вареные бобовые не люблю:)

0
Диссидент
Эксперт C
26851 / 16755 / 3673
Регистрация: 24.12.2010
Сообщений: 37,502
22.10.2014, 22:10 26
Цитата Сообщение от ValeryS Посмотреть сообщение
давай интересно будет
Вот нашел. К сожалению, комментарии ставить ленился, и сейчас с ходу не соображу, что к чему. Однако, вроде работает. Будет свободный часок и ясная голова - попробую разобраться, что ж я такое наваял...
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
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
static int Rest[8] = { 1, 7, 11, 13, 17, 19, 23, 29 };
static unsigned char *A;
static int V; // Объем массива A
#define N 12000  // До какого числа строить решето
 
main()
{ int s, p, ii, jj;
   V = N/30 + 1;
   A = (unsigned char *)malloc(V);
   A[0] = 1;
   memset(A+1, 0, V-1);
   s = sqrt(N);
   for(ii=p=0; p<=s; ii++) {
     for(jj=0; jj<8; jj++) {
       if (A[ii] &(1<<jj)) continue;
       p = 30*ii + Rest[jj]; // уже построенное простое
       Jolting(p);  // Проверка
     }
   }
   for(ii=0; ii<V; ii++) {
     for(jj=0; jj<8; jj++) {
       if (A[ii] & (1<<jj)) continue;
       printf ("%d\n", 30*ii + Rest[jj]);
     }
   }
}
// ****************
Jolting(int p)  // Вот тут сам толком не могу понять, что происходит
{ int x, d, r, i;
 
   for(x=7*p; ; x += 2*p) {
     d = x/30;
     if (d >= V) break;
     r = x%30;
     for(i=0; i<8; i++) if (r==Rest[i]) break;
     if (i==8) continue;
     A[d] |= (1<<i);
   }
}
// ****************
Несколько первых простых пропущено, их можно добавить вручную Или немного модифицировать алгоритм.
Функцию Jolting можно слегка оптимизировать, чего я делать не стал, тк. нас в первую очередь интересует объем памяти.
Так же не стал заморачиваться на проблемах больших чисел и длинной арифметики.
2
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.10.2014, 22:10
Помогаю со студенческими работами здесь

Поиск простых чисел
Всем привет, прохожу книгу Шилдта и остановился на программе:...

Поиск простых чисел
Народ, в программе нужно из введённых чисел найти и вывести простые числа(т.е. 2,3,5,7,11,13... и...

поиск простых чисел
Как найти количество цифр n- значных чисел, у которых сумма любых двух соседних цифр является...

Поиск простых чисел
to idetify if the given K is prime or not. Prime number is the number that can be divided by 1 and...


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

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru