|
3 / 3 / 1
Регистрация: 04.04.2018
Сообщений: 351
|
||||||
Vector<string> в string02.05.2019, 22:11. Показов 54877. Ответов 40
Метки нет (Все метки)
Как преобразовать vector<string> в string?
Думаю легко и я видимо не умею гуглить...
0
|
||||||
| 02.05.2019, 22:11 | |
|
Ответы с готовыми решениями:
40
Доступ к паре в map<string, vector<pair<string, string>>>Temp
Какое одинаковое значение можно вернуть из функций <string> f () и vector < <string> > f()? |
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
||||
| 04.05.2019, 21:03 | ||||
|
Значит и как переносить - тоже. С практической точки зрения важны только удобство и производительность(именно в таком порядке т.к. большинство - пользователи, а не разработчики). Вот решение notAll - самое удобное, а с точки производительности - наоборот.
0
|
||||
|
Комп_Оратор)
|
|||||||||
| 04.05.2019, 21:40 | |||||||||
С другой стороны, если бы был += (с ссылкой на объект результат), то всё копировалось бы в зарезервированную область. У списка её нет, но это частный случай, неудачный для пояснения ситуации. А выполнить += свободной операцией нельзя, ей нужен объект. Добавлено через 5 минут
0
|
|||||||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|
| 04.05.2019, 22:43 | |
|
0
|
|
|
Комп_Оратор)
|
||
| 05.05.2019, 00:14 | ||
|
1
|
||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
||
| 05.05.2019, 00:23 | ||
|
А посимвольное копирование это про внутреннюю реализацию что для insert что для чего-то другого.
0
|
||
|
Комп_Оратор)
|
|||||||
| 05.05.2019, 00:31 | |||||||
0
|
|||||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
||
| 05.05.2019, 09:15 | ||
|
0
|
||
|
Комп_Оратор)
|
|||||||
| 05.05.2019, 09:54 | |||||||
|
У списков есть resize имеющий ту же семантику. Но боль в том, что вся стандартная библиотека - зверинец разношерстной фауны. Присмотритесь. Разные названия для сходных семантик, разные порядки задания аргументов(!)... Метод копирования требует пары для интервала источника а затем итератор назначения а метод вставки - сначала итератор назначения а потом пару итераторов источника. Это значит, что эффективно работать без применения таких вот трюков (не простых) нельзя. И это сделано людьми для людей. Вот более полная специализация для списка, которая учитывает заблаговременную аллокацию путём ресайз (нужно раскомментировать вызов) :
0
|
|||||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|||
| 05.05.2019, 13:58 | |||
|
0
|
|||
|
Комп_Оратор)
|
|||
| 05.05.2019, 14:16 | |||
|
вектор строк -> строка векторе списков -> список список строк -> строка список векторов -> вектор список списков -> список хух... хорошо, что нету строк векторов/списков (из коробки). то или со временем вы измените своё мнение или нет. Стратегии на наследовании потребовали бы кучи наследников и их комбинаций. А стратегия на шаблонах, легко конфигурируются на типах при использовании, легко расширяется в процессе разработки по мере надобности не затрагивая клиентский и уже наработанный библиотечный код.
0
|
|||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
||||
| 05.05.2019, 14:26 | ||||
|
1
|
||||
|
Комп_Оратор)
|
||||
| 05.05.2019, 15:17 | ||||
S_el, я не говорю, о том, что нужно писать библиотеки на каждом шагу. Но обилие хардкода в современном мэйнстриме зашкаливает. Это не только генерённый код. Это код, который пишут вполне квалифицированные программисты под давлением сроков и прессинга. Истина где-то есть, но я не стал бы искать её в этой теме, говоря об уровне абстракции для конкретного случая. Всё хорошо, когда оно хорошо.
0
|
||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|||
| 05.05.2019, 16:27 | |||
insert это универсальное решение для вставки. Для добавления в конец универсальное решение должно называть либо push_back или, как уже выяснили, append. Любое более специализированное решение будет не менее эффективным более общего. Поэтому за вставку в любую позицию приходится чем-то платить. И если все что вам нужно это добавить что-то в конец использовать insert - избыточно. Поэтому нет, я не мог сказать что push_back универсальнее чем insert и действительно не говорил это. Вот моя цитата:
0
|
|||
|
Комп_Оратор)
|
||||||||
| 05.05.2019, 19:26 | ||||||||
|
Это потому что кто-то решил что список не должен выделять "сладкие" сплошные куски (они-де для массивов-векторов), а списки могут и побомжевать отдельными кускочками. Зачем же это резервировать. Пусть дескать берут то, что есть на данный момент. Но у списков есть важная черта, - возможность работать с адресами (валидность итераторов после любых операций не удаляющих по этим адресам). Это пошло побоку. Люди думают за других! Так же и accumulate не делает резервирования и если не сделать руками то код будет слабый. С insert та же проблема. Если реализовано хорошо то не должно быть разницы между пушами и вставкой. Просто пуши - синтаксический сахар использующий инсёрт максимально эффективно для данного типа контейнера. Поэтому ваши рассуждения звучат для меня странно. А теперь такое же уверенно-категоричное суждение: "Что бы собрать строку из строк не нужно так заумствовать!!" ![]() Мой ответ значительно мягче, чем мог бы быть. Добавлено через 27 минут
0
|
||||||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|||||
| 05.05.2019, 20:05 | |||||
numeric, т.е. основное предназначение работа с числами.
1
|
|||||
|
Комп_Оратор)
|
|||||
| 05.05.2019, 20:24 | |||||
1
|
|||||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|||||
| 05.05.2019, 21:05 | |||||
|
Я не согласен с выбранным вами подходом исключительно из практических(скорость написания, удобство, ...), а не академических соображений, но именно это - дело вкуса. Кому-то нравятся значащие отступы (Python, F#), кто-то (например я) - такой подход терпеть не может. Кого-то раздражает что экспортируемые вещи в Go начинаются с заглавной буквы, а кто-то - восторгается таким изящным подходом. Поэтому наша дискуссия не про содержание (здесь я с вами солидарен), но исключительно про форму. Вы меня убедили что insert - грамотный выбор для решаемой вами задачи(получить краткое, но эффективное решение) и сделан из практических соображений(нет у строк перегрузки для push_back и желание получить более универсальное решение).
1
|
|||||
|
Комп_Оратор)
|
||
| 05.05.2019, 22:26 | ||
|
Тут есть аналогия с тем, что многие думают, что += для строк работая по ссылке имеет дело с одной исходной строкой. А это сбывается лишь если память загодя зарезервирована. Иначе ссылка как демон, она вроде есть, ан - хвать и нету ея! (Ионан Васильевич меняет прошивку кмоп ).
0
|
||
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
||
| 05.05.2019, 23:30 | ||
|
Пример на векторах - https://ideone.com/ej4mM5
1
|
||
|
Комп_Оратор)
|
||
| 05.05.2019, 23:43 | ||
|
0
|
||
| 05.05.2019, 23:43 | |
|
Помогаю со студенческими работами здесь
40
Как перебрать все элементы в map<string, vector<string>>
Перенос данных c vector<string> в vector<double> Vector and string Vector в string Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение.
И на уровне агентов добавится между грибами или бактериями взаимодействий.
До того я пробовал подход через многомерные массивы,. . .
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|