Модераторы: bsa
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> STL и использование функций insert и erase. 
:(
    Опции темы
stat007
Дата 1.1.2009, 16:16 (ссылка)    | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 521
Регистрация: 9.10.2008

Репутация: -2
Всего: -4



Нужна подсказка в работе со списком в STL, а именно не могу разобрать в следующем:

функция insert и erase - обозначиют вставка и удаление в любом месте списка. У меня в программе ниже в строках 1 и 2, добавляется элемент на второе место списка (после первого) и удаляется так же второй элемент. Я понимаю что это из-за оператора ++i. 
Теперь сам вопрос: Как вставить элемент и удалить естественно, не 2-ой элемент списка, а какой-либо другой, к примеру первый или четвёртый??

Код

#include<iostream>
#include<list>
using namespace std;
void showlist(const char *str, const list<int> &L)
{
    list<int>::const_iterator i;
    cout<<str<<endl;
    cout<<' ';
    for(i=L.begin(); i != L.end(); ++i)
        cout<<*i<<' ';
    cout<<endl;
}
int main()
{
    list<int> L;
    int x;
    cout<<"Enter numbers, followed by 0:"<<endl;
    while(cin>>x, x!=0)
        L.push_back(x);
    showlist("Ibitial list: ", L);
    list<int>::iterator i = L.begin();
    L.insert(++i, 456);
    showlist("After insrting 456 at the second position: ", L);
    showlist("After this deletion: ", L);
    i=L.end();
    x=*--i;
    L.pop_back();
    cout<<"Deleted at the end: "<<x<<endl;
    showlist("After this deletion: ", L);
    i=L.begin();
    x=*++i;
    cout<<"To be deleted: "<<x<<endl;
    L.erase(i);
    showlist("After this deletion (of second element): ", L);
    return 0;
}


PM MAIL   Вверх
mes
Дата 1.1.2009, 16:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 79
Всего: 250



http://www.cplusplus.com/reference/std/iterator/advance.html

Это сообщение отредактировал(а) mes - 1.1.2009, 16:45


--------------------
PM MAIL WWW   Вверх
stat007
Дата 1.1.2009, 16:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 521
Регистрация: 9.10.2008

Репутация: -2
Всего: -4



mes
можно на примере? добавь всё неоходимое в мой код программы...
PM MAIL   Вверх
stat007
Дата 2.1.2009, 12:19 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 521
Регистрация: 9.10.2008

Репутация: -2
Всего: -4



ну так что.. ни кто не знает чтоли??  smile 

Это сообщение отредактировал(а) stat007 - 2.1.2009, 12:20
PM MAIL   Вверх
mes
Дата 2.1.2009, 12:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 79
Всего: 250



Цитата(stat007 @  2.1.2009,  12:19 Найти цитируемый пост)
ну так что.. ни кто не знает чтоли??  smile 

а чем пример находящийся по ссылке не устраивает?



--------------------
PM MAIL WWW   Вверх
Lazin
Дата 2.1.2009, 12:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3820
Регистрация: 11.12.2006
Где: paranoid oil empi re

Репутация: 27
Всего: 154



std::list<T>::erase - принимает в качестве параметра итератор указывающий на удаляемый элемент, насколько я понял, ты это и сам понимаешь, так зачем-же спрашивать?

Цитата(stat007 @  1.1.2009,  16:16 Найти цитируемый пост)
Теперь сам вопрос: Как вставить элемент и удалить естественно, не 2-ой элемент списка, а какой-либо другой, к примеру первый или четвёртый??
пример удаления первого элемента:
Код

if (!L.empty())
    L.erase(L.begin());




Это сообщение отредактировал(а) Lazin - 2.1.2009, 12:39
PM MAIL Skype GTalk   Вверх
stat007
Дата 2.1.2009, 20:18 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 521
Регистрация: 9.10.2008

Репутация: -2
Всего: -4



Цитата

а чем пример находящийся по ссылке не устраивает?


тот пример просто выводит 5 и всё!!!
PM MAIL   Вверх
mes
Дата 2.1.2009, 20:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 79
Всего: 250



Цитата(stat007 @  2.1.2009,  20:18 Найти цитируемый пост)

тот пример просто выводит 5 и всё!!! 

неа.. тот пример выводит 6й элемент.. вместо вывода его можно было бы и удалить..

Во первых информации на этой странице достаточно, чтоб Вам самим ответить на Ваш же вопрос.
Во вторых если бы Вы постарались и погуляли бы дальше по вышеприведенной ссылки то наткунились бы еще и на такой пример :
http://www.cplusplus.com/reference/stl/list/erase.html

Меня все время удивляют люди, которые не хотят  напречься даже подумать,а ждут готовенького и разжеванного.





--------------------
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Для новичков"
JackYF
bsa

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0797 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.