|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
||||||
Доступ по итератору к элементу вектора22.01.2016, 12:06. Показов 27052. Ответов 16
Здравствуйте! Подскажите, пожалуйста, решение данной задачи:
Дан вектор типа string, в нем есть два элемента. Необходимо добавить в третий элемент вектора равенство двух предыдущих элементов, то есть примерно так:
Возможно, я некорректно сформулировала задание, но мне кажется, смысл примерно понятен
0
|
||||||
| 22.01.2016, 12:06 | |
|
Ответы с готовыми решениями:
16
Доступ к элементу вектора строк через геттер Написать функцию для класса, возращающую данный из вектора обьектов класса по итератору вектора std::vector доступ по индексу vs доступ по итератору |
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
|
| 22.01.2016, 12:21 [ТС] | |
|
Спасибо, но компилятору это все равно не нравится, выдает:
ошибка: no match for 'operator==' (operand types are 'std::basic_string<char>' and 'int') if(*it == 0) ^
0
|
|
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
|
| 22.01.2016, 14:01 [ТС] | |
|
Да, я с этим разобралась, но все еще не понимаю, как мне работать с индексами. Ведь итератор должен проходить по значениям индексов, а получается, что он проходит по значениям элементов.
Подскажите, пожалуйста, как сделать так, чтобы он проходил по значению именно индексов. Если через итератор такое реализовать нельзя, то через что можно?
0
|
|
|
337 / 185 / 80
Регистрация: 22.08.2013
Сообщений: 724
|
|||||||
| 22.01.2016, 14:26 | |||||||
1
|
|||||||
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
||||||
| 22.01.2016, 14:30 [ТС] | ||||||
|
Извините, может я не так формулирую, но, вот что я примерно пытаюсь сказать:
Насколько я понимаю из-за того, что мы разименовываем итератор, он в цикле проходит по самим значениям элемента вектора. Как сделать так, чтобы мы имели доступ не к значениям, а к самим индексам, то есть не к "а" и "b", а к 0 и 1? Я пытаюсь сделать по-другому, компилятор собирает программу, но ничего не пишет в консоли:
nord_v, спасибо, хоть что-то стало понятнее
0
|
||||||
|
Неэпический
|
|||||||
| 22.01.2016, 14:33 | |||||||
Но если Вам нужна работа с индексами, то, возможно, проход с помощью итераторов - не Ваш выбор.
1
|
|||||||
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
||||||
| 22.01.2016, 14:41 [ТС] | ||||||
|
То есть не использовать итераторы, а использовать простой проход через цикл for ?
Я пыталась сделать проще, но компилятор выдает ошибку " no matching function for call to 'std::basic_string<char> :: push_back(__gnu_cxx::__alloc_traits<std: :allocator<std::basic_string<char> > >::value_type&)' str2.push_back(str1[i]);" ^
0
|
||||||
|
337 / 185 / 80
Регистрация: 22.08.2013
Сообщений: 724
|
||||||
| 22.01.2016, 14:55 | ||||||
Сообщение было отмечено oooooowl как решение
Решение
Вот так нужно? Или что?
0
|
||||||
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
||||||
| 22.01.2016, 15:23 [ТС] | ||||||
|
nord_v, да, примерно так, теперь буду дальше работать со строкой str2
спасибо! Добавлено через 2 минуты Croessmah, пыталась два элемента из вектора str1 (впоследствии будет больше, чем два элемента) поместить в строку str2, чтобы затем в вектор str1 поместить в конец эту самую строку str2 Добавлено через 12 минут nord_v, подскажите, почему, когда мы задаем дополнительное условие, компилятор собирает программу, но не выводит результат
0
|
||||||
|
337 / 185 / 80
Регистрация: 22.08.2013
Сообщений: 724
|
|||
| 22.01.2016, 17:42 | |||
|
Добавлено через 4 минуты Опиши ещё раз задачу, желательно с примерами.
1
|
|||
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
||||||
| 22.01.2016, 21:45 [ТС] | ||||||
|
nord_v,
Сама задача состоит в том, чтобы доказать теорему Пифагора через подобные треугольники, используя продукционную систему, то есть схему IF (что-то = чему=то) THEN (что-то = чему-то) http://cdn.bolshoyvopros.ru/fi... b8d53a.jpg Нам необходим вектор, в котором мы будем хранить все данные, а именно: 0 a/c 1 HB/a 2 b/c 3 AH/b 4 a^2 5 c*HB 6 b^2 7 c*AH 8 a^2 + b^2 9 c*(HB+AH) 10 c^2 также у нас есть те самые равенства "что-то = чему-то", то есть: 0 = 1 2 = 3 4 = 5 6 = 7 8 = 9 9 = 10 ну и в конце есть правило, которое выдает нам заветное "а^2 + b^2 = c^2", а именно: IF 8 = 9 THEN 8 = 10 Итак, возвращаясь к вектору: чтобы связи "что-то = чему-то" заработали, нам необходимо написать функцию, в которую бы подавался вектор, в которой был бы цикл, проходящий по каждому элементу вектора и если бы он по индексу находил бы два нужных элемента, то в первоначальный вектор он бы пушил новый элемент, а именно - полученное равенство, то есть примерно так:
Если честно, пока формулировала задачу, лишний раз поняла, насколько она сама по себе сырая и насколько в моей предполагаемой реализации много костылей. Но это самое простое, что вообще можно придумать для доказательства теоремы Пифагора, как мне кажется. Также, если у Вас есть предложения по улучшенной реализации (например, я хотела создавать векторы "024689" и "1357910", и потом уже их сравнивать и т.д.), то можем обсудить это уже не в данной теме, только скажите, как с Вами связаться.
0
|
||||||
|
337 / 185 / 80
Регистрация: 22.08.2013
Сообщений: 724
|
||||||
| 23.01.2016, 00:33 | ||||||
Сообщение было отмечено oooooowl как решение
Решение
Смысл задачи ускользает. Суть доказательства непонятна.
Просто код (доказательство, как таковое, отсутствует):
0
|
||||||
|
0 / 0 / 0
Регистрация: 27.01.2014
Сообщений: 48
|
|
| 23.01.2016, 11:22 [ТС] | |
|
nord_v, спасибо Вам большое) Буду разбираться дальше, спасибо!)
0
|
|
| 23.01.2016, 11:22 | |
|
Помогаю со студенческими работами здесь
17
Как обратиться к элементу вектора?
STL . Обращение к 12 элементу вектора Дифференцирование функции по элементу вектора Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|