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

Подскажите, как сократить время работы кода? Проверка на простое число

15.03.2015, 14:55. Показов 1432. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
 
using namespace std;
 
int main()
{
    int x, k = 0;
    cin >> x;
 
    for (int i = 1; i <= x; i++)
        if (x % i == 0 )
            k++;
    if (k == 2)
        cout << "prime";
    else
        cout << "composite";
    return 0;
}
программа выясняет, является ли число простым или составным
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.03.2015, 14:55
Ответы с готовыми решениями:

Как сократить время работы программы?!
Нужно сократить время работы программы по вычислению чисел Фибоначчи: Вот мой код: #include &quot;stdafx.h&quot; #include...

Как сократить время работы программы?
Вот текст олимпиадной задачи: Ваша задача – посчитать сумму двух чисел. Входные данные В единственной строке входного файла...

Как сократить время работы программы?
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import...

11
Псевдослучайный
1946 / 1146 / 98
Регистрация: 13.09.2011
Сообщений: 3,215
15.03.2015, 15:08
Достаточно перебирать делители до sqrt(x), только условие простоты нужно будет подправить.
0
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
15.03.2015, 15:28
1. Решето Эратосфена
2. Решето Аткина
3. Вероятностный тест Рабина-Миллера

Выбирай на здоровье!

Добавлено через 3 минуты
Цитата Сообщение от NoMasters Посмотреть сообщение
Достаточно перебирать делители до sqrt(x), только условие простоты нужно будет подправить.
А еще можно перебирать с шагом 2, что позволит отбросить ненужную половину четных чисел.
0
 Аватар для _Valera_
495 / 377 / 136
Регистрация: 27.01.2015
Сообщений: 1,588
15.03.2015, 17:11
Цитата Сообщение от kruglov1 Посмотреть сообщение
for (int i = 1; i <= x; i++)
if (x % i == 0 )
k++;
1) Очевидно что в любом случае число делится без остатка на себя самого и на 1, то есть уже: time-2;
2) Так же число без остатка может делится только на "половину себя" то есть time / 2; более того:
Цитата Сообщение от NoMasters Посмотреть сообщение
Достаточно перебирать делители до sqrt(x)
и

Цитата Сообщение от nonedark2008 Посмотреть сообщение
А еще можно перебирать с шагом 2, что позволит отбросить ненужную половину
четных чисел.
Так что все віглядит примерно так:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <math.h>
 
using namespace std;
 
void main()
{
    int x, k = 2;
    cin >> x;
    if(x%2 == 0 && x != 2)++k;
 
    for (int i = 3; i <= pow(x,1.0/2); i+=2)
        if (x % i == 0 ) k++;
    if (k == 2)cout << "prime";
    else cout << "composite";
    system("PAUSE");
}
0
 Аватар для mat_for_c
223 / 213 / 80
Регистрация: 26.04.2013
Сообщений: 972
15.03.2015, 21:50
Цитата Сообщение от _Valera_ Посмотреть сообщение
for (int i = 3; i <= pow(x,1.0/2); i+=2)
каждый раз вычислять корень не есть гуд.
0
 Аватар для _Valera_
495 / 377 / 136
Регистрация: 27.01.2015
Сообщений: 1,588
15.03.2015, 21:58
Цитата Сообщение от mat_for_c Посмотреть сообщение
каждый раз вычислять корень не есть гуд.
то есть вычислить его перед циклом? Спасибо учту!
0
0 / 0 / 0
Регистрация: 16.03.2015
Сообщений: 2
16.03.2015, 13:09
Цитата Сообщение от _Valera_ Посмотреть сообщение
for (int i = 3; i <= pow(x,1.0/2); i+=2)
* * * * if (x % i == 0 ) k++;
Зачем считать k?

C++
1
2
3
4
5
6
7
8
9
10
11
12
int x;
double xSqrt;
 
cin >> x;
xSqrt = pow(x, 1.0/2);
 
for (int i = 3; i <= xSqrt; i+=2)
        if (x % i == 0 )
        {
            cout << "prime";
           break;
       }
Добавлено через 18 минут
Совсем забыл. Нужно перед циклом проверить делимость на 2
0
 Аватар для _Valera_
495 / 377 / 136
Регистрация: 27.01.2015
Сообщений: 1,588
16.03.2015, 13:27
Цитата Сообщение от Viscont Посмотреть сообщение
Зачем считать k?
+1.
0
0 / 0 / 0
Регистрация: 16.03.2015
Сообщений: 2
16.03.2015, 13:32
Цитата Сообщение от Viscont Посмотреть сообщение
Совсем забыл. Нужно перед циклом проверить делимость на 2
Сам себя запутал. Мы же проверяем на простоту только нечетные числа. А нечетные не делятся на 2

Добавлено через 2 минуты
Хотя цифра 2 является простым "числом"
0
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
16.03.2015, 13:35
тема периодически возникает
вот например одна из них
Быстрая проверка натурального числа на простоту
видать поиск не работает
0
-80 / 27 / 1
Регистрация: 14.03.2015
Сообщений: 811
16.03.2015, 17:52
Математики проверят число только до половины.
0
Модератор
Эксперт по электронике
8981 / 6748 / 921
Регистрация: 14.02.2011
Сообщений: 23,871
16.03.2015, 18:12
Цитата Сообщение от gogaloh Посмотреть сообщение
Математики проверят число только до половины.
дог корня
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.03.2015, 18:12
Помогаю со студенческими работами здесь

Как сократить время работы процедуры
Здравствуйте. Собственно, сабж. MSQL. Есть исходная таблица с полями hash, id, value, date. Хочу заполнить две другие таблицы - ...

Сократить время работы и выделяемую память
Помогите оптимизировать программу. using System; class Program { static void Main(string args) { int...

Анаграммы
number_of_words = int(input()) if number_of_words &gt; 100000: exit(0) words = anagrammbl = for i in...

Модификация кода: сократить время бинарного поиска
Можете подсказать, как сократить время бинарного поиска тута: #include&lt;stdio.h&gt; main() {int N,K,mid,g,j; scanf(&quot;%d...

Счастливый билет. Надо сократить время работы программы
Написал 2 программы обе работают очень долго первая 19сек вторая 15сек А надо: Лимит времени 2000/4000/4000/4000 мс. Условие: Надо...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru