0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 3

Как оптимизировать код

22.05.2019, 20:47. Показов 924. Ответов 11

Студворк — интернет-сервис помощи студентам
мне нужно найти количество натуральных делителей числа, с ограничением в 1 с.
мой код чуть-чуть выходит за рамки этого ограничения, как его оптимизировать?
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
n = int(input())
p = 1
d = 2
s4 = 1
while n > 1 and d <= n:
    if n % d == 0:
        p = p + 1
        n //= d
    if n % d != 0:
        s4 *= p
        p = 1
        d += 1
print(s4)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.05.2019, 20:47
Ответы с готовыми решениями:

Как можно оптимизировать код? Код считывает кол-во скобок
s = input() s = cheked = set() ans = 0 L = len(s) for l in range(L+1 if L % 2 else L, 1, -2): for i in range(L-l+1): ...

Как оптимизировать код?
Школьнику Васе на лето учитель по литературе задал прочитать много художественных произведений. Как хороший ученик, Вася сходил в школьную...

Как можно оптимизировать код?
import random import string try: # Создание пустых списков total = result = # Вход в цикл проверки...

11
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.05.2019, 21:05
Вместо if n % d != 0: поставить else:
0
0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 3
22.05.2019, 21:28  [ТС]
Если так, тогда ответ не правильный выдаёт, нарыл я яму себе конечно
ответ не верный выдаёт
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
n = int(input())
p = 1
d = 2
s4 = 1
while n > 1 and d <= n:
    if n % d == 0:
        p = p + 1
        n //= d
    else:
        s4 *= p
        p = 1
        d += 1
print(s4)
Добавлено через 6 минут
iSmokeJC, к тому же, время обработки осталось чуть больше 1 с, может как-то можно саму структуру кода поменять?
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.05.2019, 21:34
try it

Python
1
2
3
4
5
6
a = int(input())
b = 0
for i in range(1, a):
    if a % i == 0:
        b += 1
print(b)
0
 Аватар для m0nte-cr1st0
1043 / 578 / 242
Регистрация: 15.01.2019
Сообщений: 2,178
Записей в блоге: 1
22.05.2019, 22:58
Kason, взять код iSmokeJC за основу, только увеличивать не на 1, а на найденный наименьший делитель.
0
Эксперт Pascal/Delphi
 Аватар для mmm_corp
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
23.05.2019, 00:53
1. для таких задач нужно брать PyPy, там все предельно просто, качаете, это такой себе питон с компиляцией, и запускаете как обычно но только через pypy3.exe

должно помочь

2. посмотреть в сторону NumPy, SciPy, думаю там такие задачи уже решены очень эффективно, это мат. библиотеки

3. цикл можно разбить по процесорам, кода готового не дам, но суть такова, разбиваете цыкл на CPUUnitCount, через multiprocess

4. если с математикой ок, то рекомендую также попробовать разбить банально на Thread и начать 2 потока,
while n > 1 and d <= n/2

while n > 1 and d <= n-n/2

ну както так, это поможет искать решение не только от начала до конца но и предугадать результат если есть статистика по угадыванию (провести тесты на некоторых числах, выявить закономерности, построить графики... в общем включить голову)
0
0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 3
23.05.2019, 18:01  [ТС]
всё бесполезно...
0
Эксперт Pascal/Delphi
 Аватар для mmm_corp
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
23.05.2019, 18:12
Цитата Сообщение от Kason Посмотреть сообщение
всё бесполезно...
неверю, не ленитесь, вы пришли за советом или за готовым кодом? если за готовым - то вам в ветку фриланса)
0
0 / 0 / 0
Регистрация: 18.11.2017
Сообщений: 16
25.05.2019, 00:27
Corp - думаю, если добавить async, то быстрее ли будет....? (неть компа рядом)
0
Эксперт Pascal/Delphi
 Аватар для mmm_corp
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
25.05.2019, 02:48
Цитата Сообщение от rewen Посмотреть сообщение
Corp - думаю, если добавить async, то быстрее ли будет....? (неть компа рядом)
асинк то каким боком ускорит? он всеголиш асинхронит код но не паралелит, да и для CPU задач он вообще бесполезен. Более того я скажу, что напр. вот на днях решал проблему паралельной загрузки, Thread как нистранно - легко и просто решает эту проблему не напрягаясь, а вот async/await - имеет оверхед свой, да и по дебильному это както - переписывать код. Так и запилил - заюзал Thread.
Здесь как я писал решение в лоб не поможет, нужно паралелить, разбивать на части, засесть за математику.
0
0 / 0 / 0
Регистрация: 18.11.2017
Сообщений: 16
25.05.2019, 12:07
Thread - подскажите, из какого стека? Пользовался multiprocessing.process - что то как то не очень быстро вышла загрузка контента (
0
Эксперт Pascal/Delphi
 Аватар для mmm_corp
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
25.05.2019, 13:04
Цитата Сообщение от rewen Посмотреть сообщение
multiprocessing.process
multiprocessing.process - создает новый процесс питона, нужно это учитывать!!!!
Thread - этого не делает, все остается в рамках одного физического потока, но благодаря механизму GIL, и версии питона не ниже 3.5 (где переключение происходит через времья а не через инструкции) скачивать по сети можно эффективно (повторюсь даже лучше чем с async/await, сам не ожидал...)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2019, 13:04
Помогаю со студенческими работами здесь

Англо-латинский словарь. Как оптимизировать код?
Привет! В интернете, конечно, уже полно решений этой задачи, но хотелось бы узнать, как можно оптимизировать свой код, не переписывая чужой...

Как оптимизировать количество вычислений функции? Написать код на Python для отделения корней
Здравствуйте! Вчера я думал, что для завершения работы над контрольной достаточно будет спросить, как вычислить порядок сходимости, но...

Оптимизировать код
Существует число N,не превосходящее 10^9.число можно разложить на множители N=B*C несколькими способами. Нужно найти и вывести минимально...

Оптимизировать код
Как можно оптимизировать этот код, чтобы время выполнения было меньше? Во входном файле 'input.txt' первая строка - цифра, означающая...

Оптимизировать и модернизировать код
Добрый день, Уважаемые форумчане! Буду благодарен в помощи решения вопроса. Есть строки кода: import requests from btc import * ...


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

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

Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru