1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
| Айра |
11.03.2008 20:28
Сообщение
#1
|
|
Профи ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 731 Пол: Женский Репутация: 25 |
Нужно оценить временную сложность алгоритма.. Например для этого кода:
program sort_par; Подскажите как это правильно сделать? Заранее, спасибо)) |
![]() ![]() |
| andriano |
12.03.2008 8:27
Сообщение
#2
|
|
Гуру ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
Насколько мне известно, оценка сложности основана на количестве операций, но не воспроизводит его один к одному.
Например, если количество операций 3(n-2)(n-1) + 7(n-2)(n-1)/(4n) + 16, то сложность оценивается как O(n^2), т.е. как все младшие степени, так и коэффициент при старшей опускаются. Кстати, в наилучшем случае сложность равна O(n), а не O(1). А оценка для среднего случая (именно она мной и приведена) совпадает с оценкой для наихудшего и составляет O(n^2). 2klem4: Русский язык допускает неоднозначность. И фраза "Как оценить" в большинстве случаев подразумевает не алгоритм оценки, а результат. Теперь по поводу алгоритма. Оценить, как всегда, можно аналитически и численно. Если бы это был алгоритм (где по-русски написано, что и ЗАЧЕМ делается), то разумнее было бы оценивать аналитически. Если же есть программа, то проще, естественно, оценить численно. В данном конкретном случае оценка проводилась по слегка измененной программе, приведенной ниже. Количество запусков - 5: при значениях n=1000, n=1000, n=1000, n=10000 и n=100000. Запуски 1-3 - чтобы оценить дисперсию, а 3-5 - сложность. Т.к. использовался random, то можно считать, что эта оценка относится к среднему значению. А оценка примерно такая: 0.45*n^2. Количество сортируемых чисел выбиралось из следующих соображений: - проводить оценку для единиц и десятков - бессмысленно, т.к. велика роль младших членов, поэтому 1000 - где-то минимально допустимое значение. - чтобы оценить динамику нужно не менее 3 точек, расположенных на одинаковом расстоянии по логарифмической шкале. - т.к. на глаз я оценил алгоритм как n^2, а мой опыт говорит, что такие алгоритмы уже при n=1000000 работают довольно долго, максимальное число составило 100000. В принципе, можно формализовать алгоритм определения сложности и написать программу, которая будет на выходе давать именно оценку сложности, т.е. одну из строк: "O(1)", "O(log(N))", "O(N)"... program sort_par; |
Айра оценка временной сложности алгоритма 11.03.2008 20:28
andriano O(n^2) 11.03.2008 22:48
klem4 andriano, помоему вопрос был поставлен достаточно ... 11.03.2008 22:53
Айра у меня получилось, что в лучшем случае (массив уже... 11.03.2008 23:40
klem4 оффтоп
Согласен, только в посте Айры такой фраз... 12.03.2008 14:59
Айра в продолжение оффтопа: была фраза "как это сд... 12.03.2008 17:31
andriano и все таки, я не понимаю _как_ Мы посчитали количе... 12.03.2008 20:09
Айра Эх.. вернемся к нашим баранам.. :unsure:
Как оц... 21.03.2008 16:32
Michael_Rybak 1) выделить переменные, относительно которых счита... 21.03.2008 16:44
Айра Спасибо! :) А если в качестве примера взять т... 21.03.2008 17:11
Michael_Rybak давай возьмем, давай :)
сразу разбиваем на послед... 21.03.2008 18:37
andriano Конкретно в той сортировке есть два вложенных цикл... 21.03.2008 18:39
Michael_Rybak andriano, минимальным анализом там видно, что внеш... 21.03.2008 18:54
andriano Ну не узнал я этого "простого пузыря" (и... 21.03.2008 21:48
Michael_Rybak Смотри, там l (маленькое L) - переменная, обознача... 21.03.2008 22:50
Айра
У меня не кривые руки.. нам на лекциях эту сортир... 21.03.2008 23:07
andriano Проблемы не с пониманием, проблемы с банальной лен... 21.03.2008 23:14
Michael_Rybak
Я рассчитывал на то, что ты поймешь, что я имею ... 22.03.2008 3:10
Айра
Ой.. действительно разные вещи..
Хм.. а в чем о... 22.03.2008 15:24
Michael_Rybak Оля, andriano имел ввиду себя. Имел ввиду, что ему... 22.03.2008 15:27![]() ![]() |
|
Текстовая версия | 10.12.2025 23:29 |