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

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

Войти
Регистрация
Восстановить пароль
 
Sivilan
6 / 6 / 0
Регистрация: 17.03.2013
Сообщений: 66
#1

Односвязный список.Сортировка перестановкой указателей - C++

16.01.2014, 21:14. Просмотров 255. Ответов 0
Метки нет (Все метки)

Добрый вечер.Мое задание:Необходимо предусмотреть режим сортировки элементов списка без перестановки самих элементов.Нужно переставлять указатели на элементы списка,пытаюсь сделать сортировку пузырька,затрудняют случаи в начале и конце.Возможно проще сделать эту сортировку,только не через массивы.Спасибо
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
145
146
147
148
149
150
#include <iostream>
using namespace std;
 
struct foot
{
    int mesto;
    foot *next;
};
 
void menu ()
{
    cout<<endl<<"\nViberite nomer deistviya";
    cout<<endl<<"1.Zapolnit' tyrnirnuy tablicy";
    cout<<endl<<"2.Sortirovat' elementi tyrnirnuy tablici ";
    cout<<endl<<"3.Pokazat' tyrnirnuy tablicy";
    cout<<endl<<"4.Ydalit' elementi tyrnirnuy tablici";
    cout<<endl<<"5.Vihod\n";
 
}
 
void add(foot ** first, int m )
{
    if ((*first)==NULL)
    {
        *first = new foot();
        (*first)->mesto = m;
        (*first)->next=NULL;
    }
    else
 {
       foot *adr = *first;
       while (adr->next)
       {
           adr=adr->next;
       }
       adr->next=new foot();
       adr=adr->next;
       adr->mesto=m;
    }
}
 
void show(foot *first)
{
 while (first!=NULL)
 {
  cout << endl << first->mesto;
  first = first->next;
 }
}
 
 void del(foot** first, int m)
{
    foot *ptmp = *first;
    int cntr = 0;
    while(ptmp!=NULL)
    {
        if(ptmp->mesto == m)
        {
            if(cntr==0)
            {
                *first = (*first)->next;
                delete ptmp;
                ptmp = 0;
            }
            else
            {
                ptmp = *first;
                while(--cntr!=0)
                    ptmp = ptmp->next;
                foot* pdel = ptmp->next;
                ptmp->next = pdel->next;
                delete pdel;
                pdel = 0;
            }
            break;
        }
        ptmp = ptmp->next;
        ++cntr;
    }
}
 
void sor(foot* first)
    {   foot *out=NULL,*sled,*pred,*dan;
        int cntr=0;
        pred=first;
        while((sled=first->next)!=NULL)
            {  while (sled!=NULL)
            {  if ((sled->mesto)>(first->mesto))
                   {
                dan=first->next;
                first->next=sled;
                sled->next=dan;
        }
        sled=sled->next;
            }
            first=first->next;
            }
            first=pred;
    }
        //for (int i=0;i<cntr)
        //{ dan=first;
        //first=first->next;
        //for (pred=out,pred=NULL;sled!=NULL && ((dan->mesto)>(dan->next->mesto));pred=sled,sled=sled->next);
                //if (pred==NULL)
//{
    //dan->next=out;
     //out=dan;
//}
//else
//{
    //dan->next=sled;pred->next=dan;
    //}
//}
 //return out;
    //}
//}
//}
 
 int main ()
 {
    int val, opt;
    foot *first = NULL;
    while(true)
    {
 
        menu();
        cin>> opt;
        switch (opt)
        {
        case 1:
         cout<<"Element dlya dobavleniya: ";
         cin>> val;
         add(&first, val);
         break;
        case 2:
            sor(first);
            break;
        case 3:
         show(first);
         break;
        case 4:
         cout<<"Element dlya udaleniya: ";
         cin>> val;
         del (&first, val);
         break;
        case 5:
            return 0;
        }
    }
 }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2014, 21:14
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Односвязный список.Сортировка перестановкой указателей (C++):

Односвязный список. Сортировка по алфавиту - C++
У меня есть односвязный список.Раньше был двухсвязный но дали задание сделать на односвязный Работает,добавляет и удаляет. ...

Кольцевой односвязный список, сортировка - C++
Помогите, пожалуйста, с сортировкой списка. #include &lt;iostream&gt; #include &lt;stdlib.h&gt; using namespace std; struct Node { int...

Сортировка методом выбора, односвязный список - C++
Добрый вечер. Такая проблема, срочно нужно сделать два задания, я сколько не пробовал - у меня ещё не получается, нужно в кратчайшие сроки....

Сформировать список из 10 книг, используя динамическую структуру данных односвязный список - C++
друзья спасайте Сформировать список из 10 книг, используя динамическую структуру данных односвязный список С++

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

Задали односвязный линейный список с целыми числами. Создать новый список, который содержит элементы заданного списка в обратном порядке - C++
Задали односвязный линейный список с целыми числами. Создать новый список, который содержит элементы заданного списка в обратном порядке.

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.01.2014, 21:14
Привет! Вот еще темы с ответами:

std::sort. Как сортировать список? (список указателей на объект) - C++
Всем доброго времени суток! Извините за флуд темами, я не специально С простыми типами то всё понятно: std::vector&lt;string&gt; vStr; ...

Массив указателей на массив строк и сортировка массива указателей - C++
Добрый день. Поступил вопрос. Есть задача. У нас встроенный массив char mass;.Мы вводим строки до тех пор, пока не будет заполнен массив...

односвязный список - C++
Доброго времени суток! У меня такой вопрос: нужно разработать класс, реализующий линейный односвязный список. Методы класса: добавление...

Односвязный список - C++
Всем привет. Помогите разобраться с односвязным списком. Вот собственно и вопросы: 1) Если я правильно понял то список это чтото вроде...


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

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

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