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

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

15.03.2015, 14:55. Показов 1394. Ответов 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
Модератор
Эксперт по электронике
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,854
16.03.2015, 13:35
тема периодически возникает
вот например одна из них
Быстрая проверка натурального числа на простоту
видать поиск не работает
0
20 / 27 / 1
Регистрация: 14.03.2015
Сообщений: 796
16.03.2015, 17:52
Математики проверят число только до половины.
0
Модератор
Эксперт по электронике
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,854
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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru