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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Почему istream::get() ? http://www.cyberforum.ru/cpp-beginners/thread1097265.html
Здравствуйте. Почему перед istream::getline, необходимо делать get(), если перед этим было cin >> char_array (filein >> char_array)? А между двумя cin >> char_array (filein >> char_array) не нужно?
C++ Сгенерировать и вывести на экран массив из целого числа n случайных чисел от -120 до 120 Сгенерировать и вывести на экран массив из целого числа n случайных чисел от -120 до 120. Вывести номер предпоследнего положительного елемента.Число n вводить пользователь. Буду очень благодарен http://www.cyberforum.ru/cpp-beginners/thread1097263.html
Найти наибольший подмассив заданного массива C++
Здравствуйте. Мне попалась следующая задачка: Имеется массив чисел. В нём могут находиться как отрицательные, так и положительные элементы. Его длина - n. Необходимо найти наибольший подмассив...
Нахождение суммы элементов массива, найти ошибку в коде C++
#include <iostream> #include <time.h> using namespace std; void fm(int a, int count){ for (int i=0; i<count; i++) a=rand()%100; } void print(int a,int count){ for (int i=0; i<count;...
C++ Вывести имя и количество букв в фамилии. Вывести самое длинное слово http://www.cyberforum.ru/cpp-beginners/thread1097241.html
Помогите сделать задачку: Вывести имя и количество букв в фамилии.Вывести самое длинное слово.На C++
C++ Добавление элемента в список с проверкой уникальности Всем привет! И сразу же к сути - не могу разобраться с добавлением элемента в список, но так что бы он не повторялся и был на своему мести, например мы добавили 7, в список 1 3 5 6 9, результат 1 3 5... подробнее

Показать сообщение отдельно
Yark0s
0 / 0 / 0
Регистрация: 18.12.2013
Сообщений: 37

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

15.02.2014, 17:36. Просмотров 507. Ответов 1
Метки (Все метки)

Как удалить конкретный элемент со списка , к примеру удалить "6" со списка "12469"!
Код:
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
//---------------------------------------------------------------------------
#include <clx.h>
#include <iostream.h>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#pragma hdrstop
//---------------------------------------------------------------------------
#pragma argsused
using namespace std;
struct Element
{
   char data;
   Element * Next;
};
// Односвязный список
class List
{
   Element * Head;
   Element * Tail;
   int Count;
 
public:
   List();
   ~List();
   // Добавление элемента в список
   // (Новый элемент становится последним)
   void Add(char data);
   // Удаление элемента списка
   // (Удаляется головной элемент)
   void bound(char data);
   void Del();
   // Удаление всего списка
   void DelAll();
   // Распечатка содержимого списка
   // (Распечатка начинается с головного элемента)
   void Print();
   // Получение количества элементов, находящихся в списке
   int GetCount();
};
 
List::List()
{
   // Изначально список пуст
   Head = Tail = NULL;
   Count = 0;
}
 
List::~List()
{
   DelAll();
}
 
int List::GetCount()
{
   return Count;
}
void List::bound(char data)
{
    Element *temp = new Element;
    temp->data = data;
    Tail = Head;
    if (Head != NULL)
    {
        while (Tail != NULL)
        {
            if (Tail->data == temp->data)
                break;
            else if (Tail->data < temp->data && Tail->Next == NULL)
            {
                Tail->Next = temp;
                break;
            }
            else if (Tail->data < temp->data && Tail->Next->data > temp->data)
            {
                temp->Next = Tail->Next;
                Tail->Next = temp;
                break;
            }
            Tail = Tail->Next;
        }
    }
    else
        Head = Tail = temp;
}
 
void List::Add(char data)
{   // создание нового элемента
   Element * temp = new Element;
   // заполнение данными
   temp->data = data;
   // следующий элемент отсутствует
   temp->Next = NULL;
   // новый элемент становится последним элементом списка
   // если он не первый добавленный
   if(Head!=NULL){
 Tail->Next=temp;
 Tail = temp;
   }
   else{
   Head=Tail=temp;
   }
}
 
void List::Del()
{
   Element * temp = Head;
   Head = Head->Next;
   delete temp;
}
 
void List::DelAll()
{
   while(Head != 0)
      Del();
}
 
void List::Print()
{
   Element * temp = Head;
   while(temp != 0)
   {
      cout << temp->data << " ";
      temp = temp->Next;
   }
   cout << "\n\n";
}
void main()
{  char q;
   // Создаем объект класса List
   List lst;
   char s[] = "12469\n";
   cout << s << "\n\n";
   int len = strlen(s);
   for(int i = 0; i < len; i++)
     lst.Add(s[i]);
   lst.Print();
   scanf("%c",&q); printf("\n");
   lst.bound(q);
    lst.Print();
//   lst.Del();
//    lst.Print();
   getch();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru