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

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

22.05.2019, 20:47. Показов 914. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru