|
0 / 0 / 0
Регистрация: 28.01.2012
Сообщений: 12
|
||||||
Скорость работы кода08.04.2022, 16:47. Показов 584. Ответов 10
Метки нет (Все метки)
Есть вот такой кусок кода:
0
|
||||||
| 08.04.2022, 16:47 | |
|
Ответы с готовыми решениями:
10
Скорость работы кода Скорость работы кода Скорость работы и правильность кода |
|
0 / 0 / 0
Регистрация: 28.01.2012
Сообщений: 12
|
|
| 08.04.2022, 17:08 [ТС] | |
|
код не несет никакой смысловой нагрузки. в нем надо только поправить вычисления в цикле, чтоб он немного быстрее начал работать.
перепробовал нагугленные методы "ускорения", но ничего не помогло..
0
|
|
|
|
||||||
| 08.04.2022, 17:27 | ||||||
|
а как можно ускорить процесс, если даже не понятно, что он делает? по крайней мере очевидных ошибок, явно замедляющих выполнение я не вижу.
единственное, что m тут видимо служит флагом. значит разумнее объявить её как boolean и когда условие оказывается истинным -- прерывать вложенный цикл, тк он после нахождения первого подходящего начинает крутиться бессмысленноДобавлено через 7 минут ну и замерять скорость обработки рандомных массивов больше похоже на мазохизм. задайте seed для randomizeнапример
0
|
||||||
|
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
|
|||
| 08.04.2022, 17:40 | |||
|
И ещё, глобальные переменные (
var объявленные до begin) в первую очередь плохо использовать из за того что такой стиль кода провоцирует баги.Но на самом деле из за того что к глобальным переменным нужен доступ откуда угодно (из любой подпрограммы) - они храняться в менее специализированных пространствах памяти и мало оптимизируются. Последний раз как я тестировал - доступ к ним был где то в 5 раз дороже, чем доступ к локальным переменным. Добавлено через 6 минут Оптимизация кода всегда состоит в понимании какие действия выполняет компьютер и каких из них можно убрать или заменить более быстрыми альтернативами с тем же результатом. Если код действительно
0
|
|||
| 08.04.2022, 17:42 | |
|
Не по теме: на счёт глобальных переменных: я бы не сказал, что они зло сами по себе. но по возможности, действительно, лучше использовать локальные. так и код чище, и, как уже сказано, производительность в основном выше. глобальные переменные, на самом деле, нужны в небольшом количестве, а для таких задач и вовсе не нужны
0
|
|
| 08.04.2022, 17:48 | |
|
Не по теме: Глобальные переменные (вместе с остальными статическими полями) реально нужны только для глобального состояния кода.
0
|
|
|
Модератор
|
||||||
| 08.04.2022, 19:49 | ||||||
|
Вы не поверите, но код можно действительно выкинуть.
![]() И вот почему. Посмотрите внимательно на строку 17: нижний предел 1, верхний k. В этой точке программы k всегда равно 0 => цикл не выполнится ни разу, m останется равно 0, строки 21-22 никогда не выполнятся. То есть, смысла искать a[i] среди b нет ровным счетом никакого. Эквивалентная оптимизация:
1
|
||||||
|
2355 / 1458 / 526
Регистрация: 07.04.2017
Сообщений: 4,798
|
|
| 08.04.2022, 19:58 | |
|
0
|
|
| 09.04.2022, 06:57 | |
|
Не по теме: bormant, а можно и без пробела…
0
|
|
| 09.04.2022, 06:57 | |
|
Помогаю со студенческими работами здесь
11
Влияние кода js на скорость работы сайта Как измерить скорость работы кода Скорость работы кода, скомпилированного в разных IDE Скорость работы кода под Иксами и в консоли
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|