|
0 / 0 / 0
Регистрация: 30.07.2012
Сообщений: 38
|
|
Как вы тестируете время выполнения программы?05.12.2013, 21:01. Показов 1297. Ответов 4
Метки нет (Все метки)
Добрый день.
Вопрос к олимпиадникам: как вы тестируете время выполнения ваших программ во время подготовки? Есть какая-нибудь задача и написано: "Время выполнения 0.5 секунд" - это на их сервере. А сколько это на моем компьютере, как узнать? Вся соль в том, что а алгоритме я почти уверен, вопрос в реализации. Как тестирую я: я внимательно смотрю на код и пытаюсь понять, что можно выкинуть (функцию, массив и пр). Затем я начинаю менять типы: вроде говорят что unsigned int работает быстрее,чем int. И т. д. Почти всегда это не приносит должного эффекта, а зачастую бывает даже хуже. К тому когда решение таки найдено, я получаю очень большое количество не правильных попыток, что не приятно. Вот сейчас у меня выполнение 0,503 секунд. И я уже не знаю что там можно еще выкинуть.
0
|
|
| 05.12.2013, 21:01 | |
|
Ответы с готовыми решениями:
4
Как уменьшить время выполнения программы? Как зафиксировать время начала выполнения программы?
|
|
Мой лучший друг-отладчик!
|
|
| 05.12.2013, 21:04 | |
|
R_e_n, кинь исходник плиз
0
|
|
|
0 / 0 / 0
Регистрация: 30.07.2012
Сообщений: 38
|
||||||||||||||||||
| 05.12.2013, 21:34 [ТС] | ||||||||||||||||||
На всякий случай выложу само задание: Во входе задано бинарное дерево поиска, такое что для любой вершины все ключи в ее левом поддереве строго меньше ее ключа, а все ключи в ее правом поддереве не меньше ее ключа. В первой строке количество вершин в дереве, во второй ключи дерева в порядке preorder. В выход выведите две строки. В первой дерево в порядке postorder, во второй дерево в порядке inorder. Количество вершин дерева не более 100 000. Значения ключей от 0 до 1 000 000 000. Добавлено через 2 минуты Что то какой то большой код получился. и еще
Добавлено через 3 минуты Может не стоит в таких случаях колдунствовать, искать ошибку в алгоритме? Добавлено через 18 минут
0
|
||||||||||||||||||
|
Мой лучший друг-отладчик!
|
|
| 05.12.2013, 21:37 | |
|
R_e_n, кинь исходник плиз.Может что придумаем.Просто обычно если такие близкие значения к обрубанию, то значит, что алгоритм выбран не совсем удачно. Ну а если знаешь, что алгоритм не подходит, но по другому не можешь решить, то тогда уже оптимизируешь всё.
Я обычно вижу по алгоритму прикидываю, сколько будет работать.Первое - асимптотика. Потом уже смотришь реализацию алгоритмов. Ну самое банальное, что могу сказать: 1) Замена ввода cin и вывода cout на scanf/printf - они работают значительно быстрее(даже фокус с ios_base::sync_with_stdio(0) не дает такого эффекта). 2) можно чутка сэкономить, делая функции inline 3) все повторяющиеся где-то одинаковые вычисления запоминаются(смотрим, чтобы например каждый раз в цикле корень не извлекался, а просто посчитаем раз и запомним его.Вот такие случаи) 4) передаем допустим в функцию вектор только адрес его, а не прост так - он копирует его в функцию и значительно падает скорость 5) где можно заменяем рекурсию на итеративный метод 6) есть такое правило - чем больше мы используем памяти, тем быстрее работает.Попробуйте может какие-то вычисления сохранять в массив, а потом вместо того, чтобы заново их считать, юзайте из массива.Только не увлекайтесь, а то и ML можно получить ![]() 7) подумайте: быть может вспомните какое-то математическое свойство иль формулу, которое реально поможет в задаче. Можно много чего ещё, но это первое, что прищло
1
|
|
|
0 / 0 / 0
Регистрация: 30.07.2012
Сообщений: 38
|
|
| 05.12.2013, 21:41 [ТС] | |
|
Спасибо, буду ошибку искать
0
|
|
| 05.12.2013, 21:41 | |
|
Помогаю со студенческими работами здесь
5
Как посчитать время выполнения программы? Как получить время выполнения программы? Как определить время выполнения программы?
Как ограничить время выполнения программы? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|