Здравствуйте, гость ( Вход | Регистрация )
![]() ![]() |
|
Litkevich Yuriy |
9.10.2009, 6:52
Сообщение
#11
|
![]() разработчик РЭА ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94
|
Qt предоставляет Link
|
|
|
|
|
rnd |
9.10.2009, 10:11
Сообщение
#12
|
|
Студент ![]() Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: 0
|
Нужно помнить, что map (QMap) сортирует элементы по ключу, именно поэтому к ключу предъявляется требование less-then comparable(т.е. определена операция <).
Поэтому при обычном переборе он и будет отдавать элементы в порядке возрастания ключей. А как он устроен внутри - дело второе. Если порядок элементов не важен (или для ключа недоступна операция <) - можно пользоваться QHash to SABROG, все-таки итераторы гораздо более универсальны, чем индексы. Индексы - это по сути только последовательные контейнеры, которые предоставляют произвольный доступ (vector, deque, в Qt QList). А вот когда существует не один вариант обхода контейнера - итераторы рулят, например дерево: post_order_iterator - узел после детей pre_order_iterator - узел перед детьми breadth_first_iterator - все узлы по уровням и т.п. Кстати, rbegin(), rend() - простейшие примеры нестандартного обхода |
|
|
|
![]() ![]() ![]() |
|
Текстовая версия | Сейчас: 30.12.2025, 8:18 |