Форум программистов, компьютерный форум CyberForum.ru

Функция вставки в list - C++

Восстановить пароль Регистрация
 
Prin53
 Аватар для Prin53
2 / 2 / 0
Регистрация: 28.02.2012
Сообщений: 117
27.04.2013, 13:51     Функция вставки в list #1
Вставить элемент Е после каждого элемента списка, превышающего некоторое значение Р.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
#include <list>
using namespace std;
void Insert (list<int> l)
{
    int p, e, t, n = 0;;
    cout << "Enter p and e: ";
    cin >> p >> e;
    std::list<int>::iterator it = l.begin(), end = l.end();
    for(; it != l.end(); it++)
    {
        if(*it > p)
        {
            l.insert(it, e);
            n++;
        }
        cout << *it << " ";
    }
    cout << endl << n << " inserts." << endl;
    for (int i = 0; i < l.size(); i++)
    {
        cout << l.front() << " ";
        l.pop_front();
    }
}
int main()
{
    const int n = 5;
    int temp;
    list<int> List;
    for (int i = 0; i < 5; i++)
    {
        cout << "Enter el. " << (i+1) << " of " << n << ": ";
        cin >> temp;
        List.push_front(temp);
    }
    Insert (List);
    system("pause");
    return 0;
}
Не работает. По всей видимости, ошибка в первом цикле процедуры insert. Подскажите, что не так?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
27.04.2013, 17:12     Функция вставки в list #2
Поблема не в первом цикле, а в выводе
C++
1
2
3
4
5
for (int i = 0; i < l.size(); i++)
{
    cout << l.front() << " ";
    l.pop_front(); // здесь вы неявно меняете условие окончания цикла
}
Prin53
 Аватар для Prin53
2 / 2 / 0
Регистрация: 28.02.2012
Сообщений: 117
27.04.2013, 17:22  [ТС]     Функция вставки в list #3
Цитата Сообщение от rangerx Посмотреть сообщение
Поблема не в первом цикле, а в выводе
C++
1
2
3
4
5
for (int i = 0; i < l.size(); i++)
{
    cout << l.front() << " ";
    l.pop_front(); // здесь вы неявно меняете условие окончания цикла
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
void Insert (list<int> l)
{
    int p, e, t, n = 0;;
    cout << "Enter p and e: ";
    cin >> p >> e;
    list<int>::iterator it = l.begin(), end = l.end();
    for(; it != l.end(); it++)
    {
        if(*it > p)
        {
            l.insert(it, e);
            n++;
        }
        cout << *it << " ";
    }
    l.begin();
    cout << endl << n << " inserts." << endl;
    list<int>::iterator i = l.begin();
    for(; i != l.end(); i++)
        cout << *i << " ";
}
А что сделать со вставкой? Она происходит до элемента, который больше р.
GetVariable
 Аватар для GetVariable
163 / 119 / 5
Регистрация: 17.03.2013
Сообщений: 283
27.04.2013, 17:28     Функция вставки в list #4
Узел односвязного списка:
C++
1
2
3
4
5
6
7
8
9
struct Node
{
    Node(int data)
    : data_(data)
    {}
    
    int data_; // полезная часть списка
    Node* next; // указатель на следующий элемент
};
Вставка узла в голову:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
Node* prepend(Node* list, Node* node) // вставляет узел в голову, возвращает указатель на голову
{
    if (node != nullptr) 
        node->next = list;
 
    return node ? node : list;   
}
Node* toList(const std::vector<int>& array) //(int array[], size_t n) создаем список из вектора
{
    Node* list = nullptr;
    
    for (size_t i = 0; i != array.size(); ++i)
        list = prepend(list, new Node(array[i]));
    
    return list;
}
 
size_t Count(Node* list, int value) // подсчитывает количество узлов с данным значением
{
    size_t count = 0;
    
    while(list)
    {
        if (list->data_ == value)
            ++count;
        list = list->next;
    }
    
    return count;
}
 
void DeleteList(Node* list) // удаляет список
{
    while (list)
    {
        Node* next = list->next;
        delete list;
        list = next;
    }
}
 
void PrintList(Node* list)
{
    while (list)
    {
        printf("%2d", list->data_);
        list = list->next;
    }
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
size_t ListLength(Node* list) // длина односвязного списка
{
    size_t length = 0;
    
    while(list)
    {
        ++length;
        list = list->next;
    }
        
    return length;
}
помогло? - [ссылка удалена]

Если что-то будет не понятно - пишите помогу.
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
27.04.2013, 18:00     Функция вставки в list #5
Цитата Сообщение от Prin53 Посмотреть сообщение
А что сделать со вставкой? Она происходит до элемента, который больше р.
C++
1
2
3
4
5
6
7
8
9
10
11
12
while(it != l.end())
{
    if(*it > p)
    {
        l.insert(++it, e);
        n++;
    }
    else
    {
        ++it;
    }
}
Yandex
Объявления
27.04.2013, 18:00     Функция вставки в list
Ответ Создать тему
Опции темы

Текущее время: 12:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru