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

Вывести все простые числа в заданном интервале

25.09.2010, 16:35. Показов 38677. Ответов 20
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Необходима Ваша помощь в написании программы на visual c++. Программы должна выводить все простые числа из заданного промежутка (начало и конец вводятся с клавиатуры) в виде
1 3 5 7
11 13 17 19
и так далее.

Заранее спасибо!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.09.2010, 16:35
Ответы с готовыми решениями:

Получить все простые числа в заданном интервале
Пожалуйста помогите решить задачу, с++ вообще не понимаю, а сдавать надо. Даны натуральные числа a, b (a<b). Получить все простые числа...

Найти все простые числа в заданном интервале
Добрый день. Задача следующая: ввести количество подсчётов (в задаче - cases). Потом столько же раз ввести А и Б. И столько же раз...

В заданном интервале натуральных чисел определить все простые числа
из заданного интервала натуральных чисел определить все простые числа

20
 Аватар для Rajd
44 / 22 / 2
Регистрация: 20.11.2008
Сообщений: 178
25.09.2010, 17:08
тебе что нужно код за тебя написать или подсобить с алгоритмом, а с кодом ты будешь сам изголяться, свои мозхги подключались к ентому вопросу?
Ни в коем случае не сочтите за оскорбление, просто случаи бывают всякие.
 Комментарий модератора 
Отправка во фриланс запрещена в тематических разделах
0
0 / 0 / 0
Регистрация: 20.09.2010
Сообщений: 8
25.09.2010, 17:14  [ТС]
код конечно тоже не помешает, больше всего интересует часть кода с определением числа на простоту. желательно с комментами)
0
бжни
 Аватар для alex_x_x
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
25.09.2010, 17:17
1. 1..N
самый простой вариант
C++
1
2
3
4
5
6
7
8
9
10
for( int i=1;i<N;++i ){
  for( int j=1;j<i;++j ){
    if( i % j == 0 ){
      break;
    }
  }
  if( i == j ){
    cout << i << endl;
  }
}
2. с проблеском мысли
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const int N = 100;
 
int main(){
  int nArr[N];
  for( int i=1;i<N;++i ){
    nArr[i] = i;
  }
  for( int i=2;i<N;++i ){
    for( int j=2;j<=i && i*j<N;++j ){
       if( 0 != nArr[j] ){ nArr[j*i] = 0; } 
    }
  }
  for( int i=1;i<N;++i ){
    if( nArr[i] != 0 ) cout << i << endl;
  }
}
2
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
25.09.2010, 17:20
Цитата Сообщение от MoNoMiZe Посмотреть сообщение
больше всего интересует часть кода с определением числа на простоту
Перебором делителей:
C++
1
2
3
4
5
6
7
8
9
10
11
// Проверяет является ли число n простым
bool IsSimple(int n) {
  if (n < 2)
    return false;
 
  for (int j = 2; j * j <= n; ++j)
    if (n % j == 0) 
      return false;
 
  return true;
}
2
 Аватар для Rajd
44 / 22 / 2
Регистрация: 20.11.2008
Сообщений: 178
25.09.2010, 17:30
Алгоритм определения простого числа прост, обычно (сколько учебных пособий я пролистал в своих поисках нужных мне ответов) такое пишут почти в самом начале учебника

принцип прост это цикл который проверяет делимость нужного нам числа на числа от 2 до половины данного числа с ппомощью оператора "%"

Добавлено через 4 минуты
CyBOSSeR, аозьму за основу твой код. не сочти за плагиат.
C++
1
2
3
4
5
6
7
bool IsSimple(int x) {
int k;
for(k=2;k<=(x<<1);k++){
?(x%k==0):return false;
}
  return true;
}
2
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
25.09.2010, 17:32
Цитата Сообщение от Rajd Посмотреть сообщение
?(x%k==0):return false;
Что это?
0
0 / 0 / 0
Регистрация: 20.09.2010
Сообщений: 8
25.09.2010, 17:36  [ТС]
всем большое спасибо)

а как еще осуществить вывод на экран простых чисел по десяткам? все просты от 0 до 10 - в 1 строке, от 11 до 20 - во второй и так далее
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
25.09.2010, 17:41
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Перебором делителей:
C++
1
2
3
4
...
  if (n < 2)
    return false;
...
А 1 разве простым числом не считается? Может как-то так?
C++
1
2
3
4
...
if ( n < 2 )
  return ( n == 1 );
...
0
бжни
 Аватар для alex_x_x
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
25.09.2010, 17:44
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
#include <iostream>
#include <ctime>
#include <cmath>
 
using namespace std;
 
const int N = 100;
 
int main(){
    int nArr[N], nLast = 1;
    for( int i=1;i<N;++i ){
        nArr[i] = i;
    }
    for( int i=2;i<N;++i ){
        if( 0 == nArr[i] ) continue; 
        for( int j=2;j<N && i*j<N;++j ){
            nArr[j*i] = 0;
        }
    }
    for( int i=1;i<N;++i ){
        if( nArr[i] != 0 ){
            if( i >= nLast*10 ){ nLast = i / 10 + 1; cout << endl; }
            cout << i << " ";
        }
    }
}
1
0 / 0 / 0
Регистрация: 20.09.2010
Сообщений: 8
25.09.2010, 17:45  [ТС]
Цитата Сообщение от easybudda Посмотреть сообщение
А 1 разве простым числом не считается? Может как-то так?
C++
1
2
3
4
...
if ( n < 2 )
  return ( n == 1 );
...
я сделал
C++
1
2
if (n < 1)
    return false;
0
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
25.09.2010, 17:45
Цитата Сообщение от easybudda Посмотреть сообщение
А 1 разве простым числом не считается?
Фиг его знает, но Википедия утверждает, что нет.
1
 Аватар для Rajd
44 / 22 / 2
Регистрация: 20.11.2008
Сообщений: 178
25.09.2010, 17:50
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Что это?
условный оператор. если мне память не отшибло проверяем остаток от деления.

Добавлено через 43 секунды
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Фиг его знает, но Википедия утверждает, что нет.
действительно нет, просто не подходит под определение в виду того что имеет всего один делитель.
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
25.09.2010, 17:52
Просто́е число́ — это натуральное число, которое имеет ровно два различных натуральных делителя: единицу и самого себя
ну наверное так...
0
Эксперт С++
 Аватар для CyBOSSeR
2348 / 1721 / 149
Регистрация: 06.03.2009
Сообщений: 3,675
25.09.2010, 18:03
Цитата Сообщение от Rajd Посмотреть сообщение
условный оператор. если мне память не отшибло проверяем остаток от деления.
Это очень похоже на безусловный тернарный оператор.
Оно вообще работает? Если даже да - никогда так не делайте - можно и без рук остаться.
if то Вам, кстати, чем не угодил?
1
 Аватар для Rajd
44 / 22 / 2
Регистрация: 20.11.2008
Сообщений: 178
25.09.2010, 18:19
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
Это очень похоже на безусловный тернарный оператор.
Оно вообще работает? Если даже да - никогда так не делайте - можно и без рук остаться.

о, точно не правильно написал сори за ошибку.
Цитата Сообщение от CyBOSSeR Посмотреть сообщение
if то Вам, кстати, чем не угодил?
он длинный для этого кода.
0
0 / 0 / 0
Регистрация: 20.09.2010
Сообщений: 8
25.09.2010, 18:42  [ТС]
не могли бы подправить код
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
bool IsSimple(int n) 
{
    if(n<1)
    return false; 
    for(int j = 2; j * j <= n; ++j)
        if (n % j == 0) 
        {
            return false;
        }
        return true;
}
 
int main()
{
        setlocale(0,"");
        int a, b, k = 1;
        cout<<"Введите начало промежутка: ";
        cin>>a;
        cout<<"Введите конец промежутка: ";
        cin>>b;
        for(int i = a; i <= b; i++)
        { 
            if(IsSimple(i))
            {
                if( i > k*10)
                cout << endl;
                cout << i << " ";
            }
        }
        getch();
        return 0;
}
куда именно надо вставить цикл по K, что бы все выводилось так как нужно?
0
 Аватар для Rajd
44 / 22 / 2
Регистрация: 20.11.2008
Сообщений: 178
26.09.2010, 05:56
Цитата Сообщение от MoNoMiZe Посмотреть сообщение
куда именно надо вставить цикл по K, что бы все выводилось так как нужно?
Что за цикл по k? и для чего он тебе нужен?

Добавлено через 5 минут
ВО переделал свой код функции. жаль что сообщение свое подправить не могу, там ОШИБИЩА спс
CyBOSSeR, что помог.

C++
1
2
3
4
5
6
7
bool IsSimple(int x) {
int k=2;
while(k<=(x<<1)){
(x%k==0)?return false:k++;
}
  return true;
}
0
0 / 0 / 0
Регистрация: 20.09.2010
Сообщений: 8
26.09.2010, 13:09  [ТС]
уже разобрался, всем еще раз спасибо, тема закрыта)
0
0 / 0 / 0
Регистрация: 26.04.2012
Сообщений: 3
07.05.2012, 15:36
А кто нибудь знает алгоритм поиска простых чисел, чтобы он не жрал много памяти...
Ведь, к примеру, используя решето Эратосфена, на определения числа порядка 1 млн тратится около 1 Мб, а на число порядка 1 млрд 1 Гб и т.д.
Если такой алгоритм есть - подскажите.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
07.05.2012, 15:36
Помогаю со студенческими работами здесь

Вывести все числа Армстронга в заданном интервале
Здравствуйте, В универе дали задание: вывести все числа Армстронга в интервале ; Понимаю что это уже давно сделали, но я хотел свою...

Вывести все нечетные числа в заданном интервале
Кому не трудно помочь с вторым и третьим вопросом. Буду очень благодарен.Спасибо.

Вывести на консоль все числа Мерсена в заданном интервале
1. Вывести на консоль все числа Мерсена в заданном интервале. Числом Мерсена называется простое число n, которое представимо в виде n=2p-1,...

Задача про простые числа. Выпишите все простые числа, находящиеся в интервале между а и б
#include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; using std::cout; using std::cin; using...

Найти все простые числа в заданном диапазоне и вывести их на экран
Доброго времени суток! Есть задачка, есть кривое решение. :) Суть задачки такова: найти все простые числа до 1000 и вывести их на...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru