|
0 / 0 / 0
Регистрация: 22.05.2019
Сообщений: 3
|
||||||
Как оптимизировать код22.05.2019, 20:47. Показов 914. Ответов 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 для отделения корней
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
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(), которая. . .
|