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

Создать динамический список. Удалить из него первый и последний элемент. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вопрос по string'у http://www.cyberforum.ru/cpp-beginners/thread286717.html
Насколько мне известно, string резервирует память, как и вектор... Если это так, возможно ли отключить резервирование, т.к. в ходе работы приложения содержимое будет добавлено всего один раз и дальше будет происходить только считывание? Или может есть какая-та более оптимальная по памяти и скорости альтернатива стрингу в таких случаях?
C++ ошибка не могу понять почему ! #include <iostream> #include <Windows.h> using namespace std; const int col=20; //создание структуры для библиотеки struct Book{ int data_izdaniya; //дата создания книги char nazvanie; //название книги char avtor; //автор книги http://www.cyberforum.ru/cpp-beginners/thread286711.html
C++ Ошибка сегментирования.
Всем доброго времени суток! Помогите пожалуйста разобраться в чем дело, пишу программу( суть найти путь в дереве, но думаю это не будет столь важно). Необходимо создать новый массив, НО, при его создании и запуске(запуске(1), компиляции проходит без ошибок) программы выдаётся ошибка "ошибка сегментирования" (пишу под линухом). Так же совсем не создаются больше переменные, та же ошибка. И еще не...
Отделить в дроби знаменатель от числителя C++
Доброго времени суток. Народ, подскажите плиз, как реализовать задачу - нужно отделить в дроби знаменатель от числителя и закинуть их в отдельные интовые переменные разрядность заранее не известна. Заранее большое спасибо...
C++ что означает данный цикл? http://www.cyberforum.ru/cpp-beginners/thread286690.html
Здравствуйте, подскажите пожалуйста что означает данный цикл? for (;;) { }
C++ Найти ряд Здравствуйте! Помогите пожалуйста, надо написать программку чтобы задать ряд - sin(1*1)/1! + (sin(2*1)+sin(2*2))/2! + (sin(3*1)+sin(3*2)+sin(3*3))/3! + (sin(4*1)+sin(4*2)+sin(4*3)+sin(4*4))/4! + ..... и так до 10. Может кто подскажет как это сделать или натолкнет на мысль? С синусом не знаю как это сделать. подробнее

Показать сообщение отдельно
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
01.05.2011, 18:29     Создать динамический список. Удалить из него первый и последний элемент.
Список. есть пример программы:
Создать динамический список. Удалить из него первый и последний элемент.
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include <iostream.h>
//структура динамического списка
struct LIST
{
    int dann;
    LIST *next;
};
LIST *head=NULL;
LIST *rear=NULL;
 
//функция формирования списка
void make(int a)
{
    LIST *ptr;
    ptr=new LIST;
    if(!head) head=ptr;
    else rear->next=ptr;
    ptr->dann=a;
    rear=ptr;
    rear->next=NULL;
}
 
//функция вывода на экран элементов списка
void print(void)
{
    LIST *ptr=head;
    while (ptr) 
    {
        cout<<ptr->dann<<" ";
        ptr=ptr->next;
    }
    cout<<endl;
}
 
//функция удаления первого элемента
void deletenhead(void)
{//указатель ptr устанавливаем на первый элемент 
    LIST *ptr=head;
    //указатель head устанавливает на второй элемент
    head=ptr->next;
    //первый элемент удаляем
    delete ptr;
}
 
//функция удаления последнего элемента
void deletenrear(void)
{
    //указатель ptr устанавливаем на начало списка 
    LIST *ptr=head;
    //Если в списке один элемент
    if (ptr==rear)  
    {
        //то его удаляем
        delete ptr;
        //указатели rear и head обнуляем
        head=rear=NULL;
    }
    //Если в списке 2 и более элементов
    else 
    {
    //указатель ptr устанавливаем на предпоследний элемент
    while (ptr->next!=rear) ptr=ptr->next;
    //последний элемент удаляем
    delete rear;
    // Теперь последний элемент - это тот,
    //на который указывает ptr
    rear=ptr;
    //у последнего элемента поле next содержит NULL
    rear->next=NULL;
    }
}
 
void main (void)
{
    int n, i, b;
    cout<<"Введите количество элементов списка: ";
    cin>>n;
    cout<<"Введите  элементы списка: "<<endl;
    for(i=0; i<n; i++)
    { cin>>b;
    make(b);}
    cout<<"Введенный список: ";
    print();
    deletenhead();
    cout<<"Список после удаления первого элемента: ";
    print();
    deletenrear();
    cout<<"Список после удаления последнего элемента: ";
    print();
}
Как на основе его изменить что бы Создать динамический список. Добавить в конец списка L1 все элементы списка L2. ?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:15. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru