Форум программистов, компьютерный форум CyberForum.ru

простые числа в диапазоне.. - C++

Восстановить пароль Регистрация
 
jusa
 Аватар для jusa
1 / 1 / 0
Регистрация: 09.01.2011
Сообщений: 12
09.01.2011, 21:36     простые числа в диапазоне.. #1
задача-вывести все простые числа в диапазоне от М до N
(диапазон с клавиатуры)


может быть есть простой более метод нахождения простых чисел в..одномерном массиве?
те что находила не смогу объяснить(
да и метод ввода в диапазоне..знаю рандомно и просто с клавиатуры элементы,а этого нет в лекциях(
подскажите?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.01.2011, 21:36     простые числа в диапазоне..
Посмотрите здесь:

C++ Создать программу, которая выводит на экран простые числа в диапазоне от 2 до 1000
Диапазон положительных чисел задан нижней и верхней границами. Распечатать все простые числа, лежащие в указанном диапазоне. C++
C++ простые числа в заданном диапазоне
Даны целые числа р и q. Получить все делители числа q, взаимно простые с р. C++
C++ Даны натуральные числа a,b(a<= Ь). Получить все простые числа р, удовлетворяющие неравенствам a<= р<= b.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
deadlock
 Аватар для deadlock
372 / 351 / 7
Регистрация: 14.12.2010
Сообщений: 1,265
09.01.2011, 22:02     простые числа в диапазоне.. #2
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
#include <iostream>
using namespace std;
 
int *Prost (int a,int b)
{
 int *p=new int[b-a];
  for (int i=0;i<b-a;i++) p[i]=0;
 p[0]=2;
 int counter=1;
  for (int i=a;i<b;i++)
   {
     int pr=0;
      for (int k=0;k<counter;k++)
       {
         if (i%p[k]!=0) pr++;
         if (k==counter-1&&pr==counter)
          {
            p[counter]=i;
            counter++;
          }
       }
   }
return p;
}
 
int main(int argc, char *argv[])
{
    int a,b,*array;
    cout<<"Vvedite granici intervala: "<<endl;
    cout<<"Minimum: ";
    cin>>a;
    cout<<"Maximum: ";
    cin>>b;
    array=new int[b-a];
    for (int i=0;i<b-a;i++) array[i]=0;
    array=Prost(3,b);
    for (int i=0;i<b-a;i++) if (array[i]!=0&&array[i]>=a) cout<<array[i]<<" ";
}
Добавлено через 19 минут
в программе необходимо ввести нижнюю границу диапазона, затем верхнюю и на экран будут выведены все простые числа зи данного диапазона
jusa
 Аватар для jusa
1 / 1 / 0
Регистрация: 09.01.2011
Сообщений: 12
09.01.2011, 22:08  [ТС]     простые числа в диапазоне.. #3

благодарствую!
и не так массивна
вы гениальны!
KEKCoGEN
Модератор
 Аватар для KEKCoGEN
1714 / 1592 / 386
Регистрация: 28.12.2010
Сообщений: 6,505
09.01.2011, 22:12     простые числа в диапазоне.. #4
по-моему достаточно проверять число на деление не до самого числа а до его корня.
deadlock
 Аватар для deadlock
372 / 351 / 7
Регистрация: 14.12.2010
Сообщений: 1,265
09.01.2011, 22:22     простые числа в диапазоне.. #5
Цитата Сообщение от KEKCoGEN Посмотреть сообщение
по-моему достаточно проверять число на деление не до самого числа а до его корня.
программа проверяет делимость числа на массив найденных простых чисел, а не на все (что согласись быстрее, чем проверять до корня).
есть более эффективные алгоритмы, но в задаче не оговорена эффективность или изящность.

недостатки программы:
1. неэффективное использование памяти;
2. генерация происходит не от минимальной границы диапазона, а от 3, просто вывод на экран начинается с минимума диапазона, что сказывается на времени работы при большой верхней границе;
но генерация массива простых происходит верно, что удовлетворяет условию задачи
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
09.01.2011, 22:31     простые числа в диапазоне.. #6
deleted
deadlock
 Аватар для deadlock
372 / 351 / 7
Регистрация: 14.12.2010
Сообщений: 1,265
09.01.2011, 22:37     простые числа в диапазоне.. #7
решето Аткина, решето Сундарама
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.01.2011, 22:38     простые числа в диапазоне..
Еще ссылки по теме:

Составить программу, которая выводит на экран все натуральные числа в диапазоне от 1 до n, которые являются степенью числа 2 C++
C++ Создать программу, которая выводит на экран простые числа в диапазоне от 2 до 1000
C++ Найти простые числа в диапазоне от 1 до 1000

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

Или воспользуйтесь поиском по форуму:
silent_1991
09.01.2011, 22:38     простые числа в диапазоне..
  #8

Не по теме:

deadlock, да-да, про них я уже тоже вспомнил)))

Yandex
Объявления
09.01.2011, 22:38     простые числа в диапазоне..
Ответ Создать тему
Опции темы

Текущее время: 01:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru