![]() |
|
|
Регистрация Восстановить пароль |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
![]() |
|
|
Опции темы | Поиск в этой теме |
![]() |
#11 | |
Форумчанин
Регистрация: 10.10.2009
Сообщений: 680
|
![]() Цитата:
З.Ы. Страшно даже смотерть, сколько времени прошло. Но вдруг кому-небудь пригодиться. |
|
![]() |
![]() |
![]() |
#12 | |
Старожил
Регистрация: 09.01.2008
Сообщений: 26,229
|
![]() Цитата:
|
|
![]() |
![]() |
![]() |
#13 |
Форумчанин
Регистрация: 10.10.2009
Сообщений: 680
|
![]()
ТЛ=TL=Time Limit
pos/delete работают явно не за О(1), там О(n) (надо просмотреть количество символов, равное части от общего числа, и потом переместить число символов, тоже прямо зависящее от общего числа). В результате получиться квадрат, хотя и с константой меньше 1. Хотя можно переписать собственный pos, использовав таблицу псевдо-хеш, потом отсортировав ее за n*log(n), потом все время использовать бинарку за log(n), но все равно остаеться delete... Можно и с ним разобраться, выбросив ввобще, свести к О(1), использовав указательные масивы для дополнения и були для удаления (если честно, даже не уверен, что в паскале такое не реализированно в самой процедуре delete, но не думаю, что все там так сложно ![]() |
![]() |
![]() |
![]() |
|
![]() |
||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Задачка | Cvieri | Microsoft Office Excel | 9 | 08.10.2008 19:44 |
Задачка | Rusl92 | Паскаль, Turbo Pascal, PascalABC.NET | 7 | 25.09.2008 16:01 |
C++ олимпиадная задачка | LastDragon | Помощь студентам | 1 | 19.06.2008 23:04 |
Олимпиадная задача | Carbon | Общие вопросы C/C++ | 2 | 23.05.2007 22:07 |