Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 02.07.2012
Сообщений: 4
1

Однонаправленный список

02.07.2012, 18:38. Просмотров 954. Ответов 6
Метки нет (Все метки)

Доброго времени суток!
Помогите поправить программу(Однонаправленный список, удалить все положительные элементы кроме последнего).
Надеюсь на вашу помощь.
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
#include <iostream.h>
#include <conio.h>
#define N 4
struct List
{ int data;
  List* next;};
  List *root,*q,*p;
  void main()
  {
  int i;
  root=new List;
  root->next=NULL;
  root->data=10;
  q=root;
  cout <<"vvedite chisla:";
  cin >>q->data;
  for (i=1; i<N; i++)
  {
   q->next=new List;
   q=q->next;
   q->next=NULL;
   }
   while (q!=0)
  { if (q>0)
    q=q->next;}
   if(q!=NULL)
   {*p=*q;
   delete q;}
 
   q=root;
   while (q!=NULL)
   {
   cout <<"result:"<<q->data;
   q=q->next;
   }
   getch();
   }
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
02.07.2012, 18:38
Ответы с готовыми решениями:

Добавить в список элемент после элемента с заданным инф.полем [Однонаправленный список]
Вообщем есть: Функция создание списка Функции вывода на экран Функция добавление элемента с...

Однонаправленный список
Добрый вечер, абсолютно не могу разобраться с работой списков (стека, очереди). Есть задание -...

Однонаправленный список
Создать однонаправленную очередь с числами в диапазоне от –50 до +50. Удалить из очереди каждый...

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

6
59 / 59 / 8
Регистрация: 29.06.2012
Сообщений: 188
02.07.2012, 19:53 2
судя по коду тут только одно данное заносится и остальное заполняется NULL... надо видимо и ввод исправить?
0
0 / 0 / 0
Регистрация: 02.07.2012
Сообщений: 4
02.07.2012, 19:57  [ТС] 3
Так и есть, а что конкретное с вводом надо поправить?
0
59 / 59 / 8
Регистрация: 29.06.2012
Сообщений: 188
02.07.2012, 20:00 4
просто какое задание то? Наверное нужно чтобы можно было ввести 4 (3) значения, которые должны быть занесены в список? И потом удалится?
0
0 / 0 / 0
Регистрация: 02.07.2012
Сообщений: 4
02.07.2012, 20:09  [ТС] 5
Задание я сверху написал, заносим элементы в список далее в списке удаляем все положительные кроме последнего.
0
59 / 59 / 8
Регистрация: 29.06.2012
Сообщений: 188
02.07.2012, 20:51 6
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
#define N 4
struct List
{ int data;
List* next;};
List *root,*q,*p, *t;
void main()
{
    int i;
    q=new List;
    cout <<"vvedite chisla:";
    cin >>q->data;
    root = q;
    for (i=1; i < N; i++)
    {
        q->next=new List;
        q = q ->next;
        cin >>q->data;      
        q->next=NULL;
    }
    q = root;
    cout <<"Data:";
    while (q!=NULL)
    {
        cout <<" "<<q->data;
        q=q->next;
    }
    q = root;
    t = q;
    while (q ->next != NULL)
    { 
        if (q ->data > 0){
            if (q == root)
                root = q->next;
            p = q -> next;
            t ->next = p -> next;
            delete q;   
            q = p;
            t = q;
        }
        else{
            t = q;
            q=q->next;
        }
    }   
    q = root;
    cout << "\nresult:";
        while (q!=NULL)
        {
            cout <<" "<<q->data;
            q=q->next;
        }
    getch();
}
1
0 / 0 / 0
Регистрация: 02.07.2012
Сообщений: 4
02.07.2012, 21:04  [ТС] 7
Leomana, моей благодарности нет передела, программа работает, огромное спасибо!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
02.07.2012, 21:04

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Однонаправленный список
#include &lt;iostream&gt; #include &lt;string&gt; using namespace std; struct Node { int data; Node*...

однонаправленный список
Прошу помощи: 1.Написать функцию для создания списка. Функция может создавать пустой список, а...

однонаправленный список
чем отличаеться point *p; p=new(point); от p=new point; ???

Однонаправленный список
Организовать ввод в однонаправленный список. Узел списка состоит из двух полей: целое число и...

Однонаправленный список
Задача:Создать линейный однонаправленный список из целых чисел.Вставить в список последний четный...

Однонаправленный Список
Как написать ф-ю добавления в конец элемента в однонаправленном списке?


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

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

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