|
0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 3
|
||||||
Как оптимизировать код22.05.2019, 20:47. Показов 924. Ответов 11
Метки python 3.7 (Все метки)
мне нужно найти количество натуральных делителей числа, с ограничением в 1 с.
мой код чуть-чуть выходит за рамки этого ограничения, как его оптимизировать?
0
|
||||||
| 22.05.2019, 20:47 | |
|
Ответы с готовыми решениями:
11
Как можно оптимизировать код? Код считывает кол-во скобок Как оптимизировать код?
|
|
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 [ТС] | ||||||
|
Если так, тогда ответ не правильный выдаёт, нарыл я яму себе конечно
ответ не верный выдаёт
iSmokeJC, к тому же, время обработки осталось чуть больше 1 с, может как-то можно саму структуру кода поменять?
0
|
||||||
|
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
|
||||||
| 22.05.2019, 21:34 | ||||||
|
try it
0
|
||||||
|
|
|
| 22.05.2019, 22:58 | |
|
Kason, взять код iSmokeJC за основу, только увеличивать не на 1, а на найденный наименьший делитель.
0
|
|
|
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
|
|
|
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
|
||
| 23.05.2019, 18:12 | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 18.11.2017
Сообщений: 16
|
|
| 25.05.2019, 00:27 | |
|
Corp - думаю, если добавить async, то быстрее ли будет....? (неть компа рядом)
0
|
|
|
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
|
||
| 25.05.2019, 02:48 | ||
|
Здесь как я писал решение в лоб не поможет, нужно паралелить, разбивать на части, засесть за математику.
0
|
||
|
0 / 0 / 0
Регистрация: 18.11.2017
Сообщений: 16
|
|
| 25.05.2019, 12:07 | |
|
Thread - подскажите, из какого стека? Пользовался multiprocessing.process - что то как то не очень быстро вышла загрузка контента (
0
|
|
|
103 / 91 / 32
Регистрация: 30.05.2015
Сообщений: 594
|
||
| 25.05.2019, 13:04 | ||
|
Thread - этого не делает, все остается в рамках одного физического потока, но благодаря механизму GIL, и версии питона не ниже 3.5 (где переключение происходит через времья а не через инструкции) скачивать по сети можно эффективно (повторюсь даже лучше чем с async/await, сам не ожидал...)
1
|
||
| 25.05.2019, 13:04 | |
|
Помогаю со студенческими работами здесь
12
Как оптимизировать количество вычислений функции? Написать код на Python для отделения корней
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
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, то после закрытия окошка. . .
|