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

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

Войти
Регистрация
Восстановить пароль
 
mcpetters
0 / 0 / 0
Регистрация: 24.05.2012
Сообщений: 11
#1

Работа с односвязным списком (удаление четных элементов) - C++

03.12.2012, 22:51. Просмотров 617. Ответов 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
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
#include <stdio.h>
#include <string.h>
 
class elle_magazine
{
  public:
    int year;
   // char name [40];
    int kstranic;
    elle_magazine *pNext;
};
 
elle_magazine *pHead=NULL;
 
elle_magazine *push1 (elle_magazine **pT, int a, int b)
{
 
  elle_magazine *pTemp;
  pTemp=new elle_magazine;
  if (pTemp==NULL) return 0;
 
 // strcpy (pTemp->name,n);
  pTemp->year=a;
  pTemp->kstranic=b;
  pTemp->pNext=*pT;
  *pT=pTemp;
  return *pT;
}
 
elle_magazine *push0 (elle_magazine *pHead)
{
  int a,b,i=0;
 
  elle_magazine *pT=pHead;
 
 
  printf ("vvedite god vipuska:\n");
  scanf ("%d",&a);
  printf ("vvedite kolichestvo stranic:\n");
  scanf ("%d",&b);
  printf ("vvod okonchen.\n");
  printf("\n");
  printf("\n");
  pHead=push1 (&pT,a,b);
  return pHead;
}
 
int watch (elle_magazine *pHead)
{
  elle_magazine *pTemp;
 
  if (!pHead) return 2;
 
  pTemp=pHead;
  while (pTemp!=NULL)
  {
    printf ("God vipuska: %d\n",pTemp->year);
 printf ("kolichestvo stranic: %d\n",pTemp->kstranic);
 printf("\n");
 printf("\n");
 pTemp=pTemp->pNext;
  }
  return 0;
}
 
int menu ()
{
  int s=0;
 
  scanf ("%d",&s);
  return s;
}
 
int main ()
{
  
  int x=0;
  
  while (x!=4)
  {
 printf ("menu\n 1-dobavit\n 2-prosmotret\n 3-algoritm\n 4-vihod\n");
    x=menu ();
    switch (x)
    {
      case 1: pHead=push0(pHead); break;
      case 2: watch (pHead); break;
      case 3: break;
      case 4: break;
    }
  }
  return 0;
}
Заранее благодарю
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.12.2012, 22:51
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Работа с односвязным списком (удаление четных элементов) (C++):

Работа с односвязным списком - C++
Есть два вопроса 1)как найти сумму двух соседних элементов элемента x. 2)Как сделать чтоб функция RemovePositive удаляла все...

Работа с односвязным списком - C++
Дан односвязный список. Класс студент (фамилия группа). Сделать меню, т.е. удаление элемента из начала списка, добавление элемента в начало...

Работа с односвязным линейным списком - C++
Здравствуйте, нужна ваша помощь , нужно програмка для работы с односвязным линейным списком а именно создание,удаление и поиск по значению...

Работа с линейным односвязным (двухсвязным) списком - C++
Создать линейный односвязный (двухсвязный) список. Из списка удалить положительные элементы, превышающие заданную величину, а затем...

Работа с односвязным списком, неправильно вызываются функции - C++
В int main() некорректно вызываются функции, в чем может быть дело?(программа на двух файлах) #include&lt;cassert&gt; ...

Работа с односвязным списком (минимизировать время выполнения программы) - C++
Нужна помощь в УСОВЕРШЕНСТВОВАНИИ именно данного списка. Проблема во времени работы,его нужно минимизировать. Приму любую помощь. Всем...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Vladimir.
155 / 155 / 10
Регистрация: 24.11.2009
Сообщений: 375
04.12.2012, 05:59 #2
C++
1
2
3
4
5
6
7
8
if (pHead = NULL ) {/*Исключение = пустой список*/}
tmp = pHead->pNext;
 
while(tmp){
delme = tmp->pNext;
tmp = tmp->pNext->pNext;
delete delme;
}
где tmp и delme - указатели на объекты elle_magazine

Добавлено через 38 минут
прошу прощения, спросонок дурака свалял - в приведенном выше коде распадается связь списка. Цикл выглядит так:
C++
1
2
3
4
5
6
7
8
while(tmp){
delme = tmp->pNext;
if(delme){
tmp->pNext = delme->pNext;
tmp = delme->pNext;
delete delme;
}
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.12.2012, 05:59
Привет! Вот еще темы с ответами:

Задача с односвязным списком - C++
Ребята, нужна помощь, кто может составьте. Буду благодерен. У меня не получается, т.к руки кривые. Задача: Напишите программу,...

Реализация с односвязным списком - C++
Приветствую! Есть созданная программа: #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;clocale&gt; #include &lt;string.h&gt; #include...

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

Полиморфизм в сочетании с односвязным списком - C++
Всем доброго времени суток!) В общем, появилась такая проблема: нужно реализовать полиморфизм, при этом используя односвязный список,...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

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