Форум программистов, компьютерный форум, киберфорум
Peoples
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

Односвязный линейный список(List) C++

Запись от Peoples размещена 24.07.2016 в 13:01
Показов 3410 Комментарии 3

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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#include <iostream>
using namespace std;
struct element {
    int x;
    element *next;
};
class List {
    private:
        element *head; // голова списка
    public:
        List() {
            head=NULL;   // констуктор
        }
        ~List(); // Деструктор
        void Add(int x); // добавление элемента в начало списка
        void Show(); // отображение списка
        void addtail(int x); // добавление элемента в конец списка
        void del(int n);  // удаление элемента по номеру
        int siz();    // количество элементов списка
        void prinfi(int n); // вывод элемента по номеру
};
List::~List() {
    while(head!=NULL) { // пока указатель не пуст
        element *temp=head->next; // переменная хранения следующего элемента
        delete head; // освобождаем первый элемнет
        head=temp; // переходим к след элементу, пока он не станет последним
    }
}
void List::Add(int x) {
    element *temp=new element; // выделяет память
    temp->x=x;     // приравниваем х
    temp->next=head; // указываем на следующий элемент
    head=temp; // следующий элемент-новый элемент
}
void List::Show() {
    element *temp=head; //указатель на начало списка
    while(temp!=NULL) { // пока список не опустеет
        cout<<temp->x<<" ";   // вывод значения
        temp=temp->next; // указываем на след элемент
    }
}
void List::addtail(int x) {
    element *newlink=new element; //выделяем память под элемент
    newlink=head; // указывем на начало
    while(newlink->next!=NULL) // пока не последний элемнет
        newlink=newlink->next; // передвигаем
    element *newlin= new element;  // новый
    newlin->x=x; // приравниваем значение
    newlin->next=NULL;      // указывем что он последний
    newlink->next=newlin;     // указываем на изначальный эл
}
void List::del(int n) {
    if(head!=NULL) {
        element *temp=head, *helping=head;
        for(int i=0; i<n; i++) {
            helping=temp;   // предыдущее значение temp
            temp=temp->next;
        }
        if(temp==head) { // если элемент который надо удалить первый
            head=temp->next;
        } else {
            helping->next=temp->next;
        }
        delete(temp);
    }
}
int List::siz() {
    int co=0; // счётчик
    element *temp=head;
    while(temp!=NULL) {  // пока есть элементы
        temp=temp->next; // указывем на след элемент
        co++;   // наращиваем счётчик
    }
    return co;      // возвращаем значение счётчика
}
void List::prinfi(int n) {
    if(head!=NULL) {
        element *temp=head, *helping=head;
        for(int i=0; i<n; i++) {
            helping=temp;   // предыдущее значение temp
            temp=temp->next;
        }
        if(temp==head) { // если элемент который  первый
            head=temp->next;
        } else {
            helping->next=temp->next;
        }
        cout<<temp->x;
    }
}
int List::ma(){     // нахождение максимального элемента 
    element *temp=head;
    element *hel=head;
    int max=temp->x;
    while(hel!=NULL){
        if(max<=hel->x){
            max=hel->x;
        }
        hel=hel->next;
    }
    return max;
}
int main() {
    List list;
    for(int i=0; i<10; i++) {
        list.Add(i);
    }
    list.Show();
    cout<<endl;
    list.addtail(21);
    list.Show();
    cout<<endl;
    list.Add(22);
    list.Show();
    cout<<endl;
    list.prinfi(11);
    return 0;
}
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 3
Комментарии
  1. Старый комментарий
    Аватар для Avazart
    1. template ?
    2. Почему разная нотация?
    Запись от Avazart размещена 24.07.2016 в 13:53 Avazart вне форума
  2. Старый комментарий
    Аватар для shilko2013
    Не плохо бы шаблоном...
    Запись от shilko2013 размещена 24.07.2016 в 13:58 shilko2013 вне форума
  3. Старый комментарий
    Шаблоном чуть позже
    Запись от Peoples размещена 24.07.2016 в 14:03 Peoples вне форума
 
Новые блоги и статьи
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
Модель здравосохранения 17. Планы на выгорание
anaschu 23.05.2026
Вот конкретная схема реализации: В классе Работник добавить: накопленнаяУсталость — растёт каждый час работы, снижается в перерывы и болезни коэффициентПрезентеизма — снижает продуктивность. . .
Изменение цветов в палитре gif файла aka фавикона
russiannick 23.05.2026
Изменение цветов в палитре gif файла, юзаемого как фавиконка в составе html-файла, помещенная в base64, средствами нативного Java Script, навеянное сном в майский день. Для работы необходим браузер,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru