|
0 / 0 / 0
Регистрация: 29.01.2022
Сообщений: 28
|
||||||
Ускорить выполнение кода09.02.2022, 10:03. Показов 749. Ответов 1
Метки нет (Все метки)
Дано задание написать и упростить данный псевдокод:
function Foo(array_of_ints a): // входные параметры: массив целых чисел result = 0 while size(a) > 2: // пока длина массива не меньше двух элементов sort(a) // отсортировать массив по возрастанию элементов n = size(a) x = a[0] + a[n - 2] result += x // добавить x в накапливаемому результату delete(a, n-2) // удалить элемент по индексу (n-2) delete(a, 0) // удалить элемент по индексу 0 add(a, x) // добавить элемент по значением x в конец массива return sum(a) + result // к накапливаемому результату добавить сумму элементов Я код написал
0
|
||||||
| 09.02.2022, 10:03 | |
|
Ответы с готовыми решениями:
1
Ускорить выполнение кода Возможно ли как-то ускорить выполнение кода? Код внутри.
|
|
2639 / 1567 / 853
Регистрация: 23.02.2019
Сообщений: 3,876
|
||||||
| 09.02.2022, 11:51 | ||||||
Сообщение было отмечено Rotteng как решение
Решение
Rotteng, сейчас у вас постоянно создаются новые массивы и это лишние накладные расходы, тем более если массивы большого размера.
Так как исходный массив нацелен только на "уменьшение", то вы можете попробовать воспользоваться только одним массивом. А для ограничения диапазона (откуда до куда) перебирать элементы - создайте две переменные и манипулируйте ими при переборе, сортировке, удалении и вставки элементов в этот массив. Добавлено через 51 минуту Ещё можно сэкономить на сортировке элементов. Достаточно сделать полную сортировку в самом начале, а затем только корректировать последние добавленные элементы в конце. Я оставлю код своего решения, возможно пригодится. Но вы сначала попробуйте сами реализовать. Возможно придумаете ещё какие-нибудь оптимизации.
2
|
||||||
| 09.02.2022, 11:51 | |
|
Помогаю со студенческими работами здесь
2
Как ускорить выполнение цикла на Update Как можно ускорить выполнение программы? Как ускорить выполнение Settings.Default.Save()? Как ускорить выполнение кода? (Получение цвета пикселя, сравнение и выполнение действия) Ускорить выполнение рекурсивного кода Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. На мобильном - сканируйте QR-код. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|