170 похожих чатов

Почему в std::vector нету метода pop который бы возвращал значение

?

23 ответов

21 просмотр

Потому что vector это не stack

Есть front, back, вытащил и удаляй как и у list

Maks- Автор вопроса
Boris Usievich
Потому что vector это не stack

std::stack::pop тоже не возвращает значение

Maks- Автор вопроса
Антон
Есть front, back, вытащил и удаляй как и у list

это понятно, но почему нет метода который бы так сразу делал в std? как в java, ruby, python, etc

Антон
Есть front, back, вытащил и удаляй как и у list

Если захочется после осознания, что это O(N)

Maks
это понятно, но почему нет метода который бы так с...

https://stackoverflow.com/questions/25035691/why-doesnt-stdqueuepop-return-value

Maks- Автор вопроса
Maks- Автор вопроса
Boris Usievich
Если захочется после осознания, что это O(N)

Тогда используй list там за константу эти операции

Maks
а разве тогда проводиться realloc ?

смещение происходит на место удаленного всех оставшихся в векторе элементов

Антон
А если с конца то тоже будет пересчет?

нет, если с конца то никакого смещения не будет

Maks
это понятно, но почему нет метода который бы так с...

Почему должно быть как в Java? На самом деле из-за сложности этой операции, она O(n)

Из-за безопасности исключений. В этом случае нельзя гарантировать, что вектор останется в прошлом состоянии, если там эксепшн вылетит

Слава
Из-за безопасности исключений. В этом случае нельз...

добавлю ссылочку с таймкодом, если никто не против https://www.youtube.com/watch?v=d0iqsUx_Aow&t=1750s

Boris Usievich
Если захочется после осознания, что это O(N)

Все ещё хочется и тоже не понимаю, почему нет

Слава
Из-за безопасности исключений. В этом случае нельз...

А что если с новыми requires сделать так, чтобы pop возвращал значение если copy/move конструктор noexcept?

Похожие вопросы

Обсуждают сегодня

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
Такой вопрос: Почему DocLister, если указать другие шаблоны для пагинации - ко всем указанными шаблоном присваивается пустая строка?
Кирилл Гацевич
11
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Карта сайта