![]() |
Модераторы: Snowy, MetalFan, bems, Poseidon |
![]() ![]() ![]() |
|
Dmitry1987 |
|
|||
Новичок Профиль Группа: Участник Сообщений: 42 Регистрация: 3.5.2008 Репутация: нет Всего: нет |
Есть отсортированный список (TStringList) значений:
1 1 2 3 3 4 5 Задача: оставить в списке только цепочки значений (т.е. удалить не дубликаты). Как максимально быстро это сделать (за один проход)? |
|||
|
||||
Illusion Dolphin |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1198 Регистрация: 3.5.2003 Репутация: 5 Всего: 63 |
Одиночное значение это когда пред элемент и след элемент не равны текущему.
-------------------- В мире всего две бесконечности: вселенная и человеческая глупость... На счёт вселенной я не уверен. Шифрование и организация фотографий - Photo Database 4.5 |
|||
|
||||
БелАмор |
|
||||
![]() Бывалый ![]() Профиль Группа: Участник Сообщений: 209 Регистрация: 10.6.2010 Где: Россия Репутация: 7 Всего: 17 |
Если я правильно понял, нужно удалить значения, встречающиеся только один раз? Т.е. в вашем примере таким образом? 1 1 2 // удалить 3 3 4 // удалить 5 // удалить Тогда алгоритм может выглядеть примерно так:
Это сообщение отредактировал(а) БелАмор - 5.12.2013, 11:02 |
||||
|
|||||
БелАмор |
|
|||
![]() Бывалый ![]() Профиль Группа: Участник Сообщений: 209 Регистрация: 10.6.2010 Где: Россия Репутация: 7 Всего: 17 |
Кстати, в приведённом мной алгоритме не обрабатывается уникальный элемент в начале списка (например, в приведённом примере добавить один "0" в начало).
Исправленный вариант:
|
|||
|
||||
fastergus2dog |
|
|||
Новичок Профиль Группа: Участник Сообщений: 4 Регистрация: 6.7.2013 Репутация: нет Всего: нет |
За один проход никак. Все равно нужно использовать цыкл который будет делать переборку данных.
Это сообщение отредактировал(а) fastergus2dog - 3.1.2014, 01:18 |
|||
|
||||
northener |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1361 Регистрация: 2.9.2010 Репутация: 12 Всего: 20 |
С чего бы это? Топик невнимательно прочитали? Для отсортированного списка достаточно одного прохода. -------------------- Но только лошади летают вдохновенно. Иначе лошади разбились бы мгновенно! |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Delphi: Для новичков" | |
|
Запрещается! 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, MetalFan, bems, Poseidon, Rrader. |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Delphi: Для новичков | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |