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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Prin53
2 / 2 / 0
Регистрация: 28.02.2012
Сообщений: 117
#1

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

27.04.2013, 13:51. Просмотров 1473. Ответов 4
Метки нет (Все метки)

Вставить элемент Е после каждого элемента списка, превышающего некоторое значение Р.

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. Подскажите, что не так?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.04.2013, 13:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Функция вставки в list (C++):

Скорость вставки и удаления в Std::list - C++
в википедии написано: я никак не пойму как в двусвязном списке может быть быстрая вставка и удаление, ведь чтобы найти нужный элемент...

STL list. В изначально пустой список вставить 100 элементов путем вставки в случайную позицию - C++
В изначально пустой список вставить 100 элементов путем вставки в случайную позицию. Случайная позиция генерируется каждый раз заново при...

Функция вставки подстроки в строку - C++
Нужна задача с функцией вставки подстроки в строку. P.S. Функция не должна иметь системных функций, т.е. типо я сам ее написал.

Функция вставки подстроки в строку. - C++
size_t n; string S1,S; cout&lt;&lt;&quot;Input S1 : &quot;; getline(cin,S1,'\n'); cout&lt;&lt;&quot;Input S : &quot;; getline(cin,S,'\n'); cout&lt;&lt;&quot;Input...

Не работает функция вставки в начало списка - C++
Добрый день. Учусь работать с линейным списком, пишу программу, которая должна выполнять условие: Вставить заданное число элементов перед...

Функция вставки элемента в циклический список - C++
Добрый день. Возник такой вопрос. Нам дано циклический список. Нужно написать функцию, которая будет вставлять елементы если будет введен...

4
rangerx
1933 / 1542 / 141
Регистрация: 31.05.2009
Сообщений: 2,913
27.04.2013, 17:12 #2
Поблема не в первом цикле, а в выводе
C++
1
2
3
4
5
for (int i = 0; i < l.size(); i++)
{
    cout << l.front() << " ";
    l.pop_front(); // здесь вы неявно меняете условие окончания цикла
}
1
Prin53
2 / 2 / 0
Регистрация: 28.02.2012
Сообщений: 117
27.04.2013, 17:22  [ТС] #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 << " ";
}
А что сделать со вставкой? Она происходит до элемента, который больше р.
0
GetVariable
163 / 119 / 5
Регистрация: 17.03.2013
Сообщений: 283
27.04.2013, 17:28 #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;
}
помогло? - [ссылка удалена]

Если что-то будет не понятно - пишите помогу.
1
rangerx
1933 / 1542 / 141
Регистрация: 31.05.2009
Сообщений: 2,913
27.04.2013, 18:00 #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;
    }
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.04.2013, 18:00
Привет! Вот еще темы с ответами:

Функция для вставки элемента в массив - C++
#include &lt;iostream&gt; #include &lt;stdio.h&gt; #include &lt;malloc.h&gt; using namespace std; void insert(int *elem, int index,int *ptr,int *n) ...

Функция вставки символа в начало строки - C++
Здравствуйте,не подскажите как должна быть написана это функция Функция void insertOneSymb(char* str, char symb) получает строку, символ...

Функция insert для list - C++
Задание: С помощью функции insert заполнить первый список элементами ранее созданного и проинициализированного массива, состоящего из 3...

Функция unique для list - C++
Взято отсюда. The second version (2), takes as argument a specific comparison function that determine the &quot;uniqueness&quot; of an element. In...


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

Или воспользуйтесь поиском по форуму:
5
Yandex
Объявления
27.04.2013, 18:00
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru