Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
0 / 0 / 0
Регистрация: 31.08.2016
Сообщений: 38

"range-base for" и проверка на последний элемент в std::set<std::string>

02.04.2017, 18:50. Показов 2976. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.
Голова совсем не варит. Как мне организовать простую проверку на послений элемент без введения счетчика а просто сравнивая адреса итераторов.
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
        std::map<char, std::set<std::string>>m = { {'A',{"array","apple","always","accord"}},
{'B',{"bullet","bill","back","BIOS"}},{'C',{"current","Canada","cross","cute"}} };
            
        {
            for (auto&i : m) {//pair
                std::cout << i.first <<": ";
                for (auto& j : i.second) {//set of string
                    if (j!=i.second.end()) {// ЗДЕСЬ Я ХОТЕЛ ДЕЛАТЬ ПРОВЕРКУ 
                        std::cout << j<<", "; 
                    }
                    else {
                        std::cout << j;
                    }
                }
            }
        }
        __asm nop
    }
Собственно вот код. Суть такая хочу проверять не последний ли элемент в дереве.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.04.2017, 18:50
Ответы с готовыми решениями:

ошибка error: cannot convert 'std::string {aka std::basic_string<char>}' to 'std::string* {aka std::basic_stri
на вод поступают 2 строки типа string. определить количество вхождений строки 2 в строку 1 ошибка error: cannot convert 'std::string {aka...

Передача функции указатель на элемент std::vector<std::string>
Доброй ночи тем, кому не спится (или живет в другом часовом поясе:p)! Есть функция, требующая в качестве параметра указатель на...

STL std::set, std::pair, std::make_pair
Я не знаю как описать тему в двух словах, поэтому не обращайте внимание на название темы. Собственно перейдем к нашим баранам: есть...

8
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
02.04.2017, 19:09
Лучший ответ Сообщение было отмечено o4enslabijcoder как решение

Решение

Цитата Сообщение от o4enslabijcoder Посмотреть сообщение
C++
1
if (j!=i.second.end())
end - это уже после последнего элемента.
а проверить можно так: std::addressof(j) != std::addressof(*std::prev(i.second.end()));
1
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
02.04.2017, 19:20
C++
1
2
3
4
5
for (std::set<std::string>::iterator it = i.second.begin(); it != i.second.end();)
{
  std::cout << *it;
  if (++it != i.second.end()) std::cout << ", "; 
}
0
Вездепух
Эксперт CЭксперт С++
 Аватар для TheCalligrapher
12937 / 6804 / 1821
Регистрация: 18.10.2014
Сообщений: 17,219
02.04.2017, 19:55
Лучший ответ Сообщение было отмечено o4enslabijcoder как решение

Решение

Цитата Сообщение от o4enslabijcoder Посмотреть сообщение
Как мне организовать простую проверку на послений элемент без введения счетчика а просто сравнивая адреса итераторов.
Вменяемо - никак. Если вам нужна особая обработка для последнего элемента, то что здесь вообще делает range-based for?

О каких "счетчиках" идет речь - не ясно. Напишите обычный нормальный цикл с итераторами и сравнивайте итераторы (итераторы, а не какие-то "адреса итераторов").
0
0 / 0 / 0
Регистрация: 31.08.2016
Сообщений: 38
02.04.2017, 22:40  [ТС]
Все спасибо за мнения)

Добавлено через 6 минут
sdelal
C
1
(std::addressof(j)!=std::addressof(*(--i.second.end())))
0
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
02.04.2017, 23:20
o4enslabijcoder, правильно, не эксперт С++ плохого не посоветует!
1
02.04.2017, 23:34

Не по теме:

А с точки зрения оптимальности?

0
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
03.04.2017, 05:24
rikimaru2013, где вы увидели, что это мой совет? ТС спросил, я сказал, как можно, я не говорил, что это хоть сколько-нибудь правильно.
ваше невежество сравнимо только с вашим ЧСВ.
0
Неэпический
 Аватар для Croessmah
18146 / 10730 / 2066
Регистрация: 27.09.2012
Сообщений: 27,030
Записей в блоге: 1
03.04.2017, 06:15
Range-Based for для определённого диапазона
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.04.2017, 06:15
Помогаю со студенческими работами здесь

Поиск в std::vector < std::pair<UInt32, std::string> >
Подскажите пожалуйста, как осуществить поиск элемента в std::vector &lt; std::pair&lt;UInt32, std::string&gt; &gt; по ключу, а...

Std::set проглатывает std::string{"b"}
Олимпиадное задание. Мультиклавиатура — это обычная клавиатура с множеством выходов, каждый из которых можно подключить к одному...

На основе исходного std::vector<std::string> содержащего числа, создать std::vector<int> с этими же числами
подскажите есть вот такая задача. Есть список . Создать второй список, в котором будут все эти же числа, но не в виде строк, а в виде...

std::string Зачем нужен std::string::compare, если есть перегруженный оператор ==?
Зачем нужен std::string::compare, если есть перегруженный оператор ==?

Запрошено преобразование от ‘const std::string*’ к нескалярному типу ‘std::string’
private: std::string firstName; }; std::string ClientData::getFirstName() const{ return firstName; } Дает в итоге...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru