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

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

Восстановить пароль Регистрация
 
кщтеук34
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 63
01.03.2013, 21:06     Работа со связанным списком (смена двух чисел местами в списке) #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
#include "stdafx.h"
#include <iostream>
#include <time.h>
using namespace std;
struct TNode {
int value;
TNode* pnext;
};
 void add2list(TNode **pphead, int val)
{
TNode **pp = pphead, *pnew;
while(*pp)
{
if(val < (*pp)->value)
break;
else
pp = &((*pp)->pnext);
}
pnew = new TNode;
pnew->value = val;
pnew->pnext = *pp;
*pp = pnew;
}
 
 void print(TNode *phead)
{
TNode* p = phead;
while(p)
{
cout << p->value << ' ';
p = p->pnext;
}
cout << endl;
}
 void deleteList(TNode *phead)
{
if(phead)
{
deleteList(phead->pnext);
if(phead)
delete phead;
}
}
 
 void Enter(TNode **pphead, int num1){
int rt1,rt2;
cout << "Elements 1:" << endl;
cin>>rt1;
cout << "Elements 2" << endl;
cin>>rt2;
//тут что то написать нужно но не знаю как(
 }
 
int main()
{
int res1;
TNode *phead = 0;
srand(time(0));
for(int i = 0; i < 10; ++i)
add2list(&phead,res1=rand() % 100);
cout << "Elements of the list:" << endl;
 
print(phead);
deleteList(phead);
Enter(&phead,res1);
return 0;
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
m1Rr0r
 Аватар для m1Rr0r
247 / 230 / 15
Регистрация: 05.02.2010
Сообщений: 3,213
Завершенные тесты: 2
01.03.2013, 21:53     Работа со связанным списком (смена двух чисел местами в списке) #2
Как вариант...
C++
1
2
3
4
5
6
7
8
9
void Swap(Node *a, Node *b)  {
Node *tmp, *tmp_next;
tmp = a;
tmp_next = a->next;
a = b;
a->next = b->next;
b = tmp;
b->next = tmp_next;
}
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
01.03.2013, 22:22     Работа со связанным списком (смена двух чисел местами в списке) #3
Цитата Сообщение от m1Rr0r Посмотреть сообщение
void Swap(Node *a, Node *b) *{
Node *tmp, *tmp_next;
tmp = a;
tmp_next = a->next;
a = b;
a->next = b->next;
b = tmp;
b->next = tmp_next;
}
что-то не верится, что это сработает.

Добавлено через 1 минуту
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
a = b;
a->next = b->next;
это вообще масло масляное

Добавлено через 49 секунд
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
b->next = tmp_next;
можно подумать, они не равны до этого были.
кщтеук34
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 63
01.03.2013, 22:43  [ТС]     Работа со связанным списком (смена двух чисел местами в списке) #4
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
что-то не верится, что это сработает.

Добавлено через 1 минуту

это вообще масло масляное

Добавлено через 49 секунд

можно подумать, они не равны до этого были.
подскажи как надо?
Kuzia domovenok
 Аватар для Kuzia domovenok
1882 / 1737 / 116
Регистрация: 25.03.2012
Сообщений: 5,907
Записей в блоге: 1
01.03.2013, 22:55     Работа со связанным списком (смена двух чисел местами в списке) #5
Цитата Сообщение от кщтеук34 Посмотреть сообщение
подскажи как надо?
тебе это случайно не для сортировки пузырьком надо? Ща напишу. Просто в общем случае придётся рассматривать несколько вариантов: когда элементы подряд идут, когда не подряд...
кщтеук34
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 63
01.03.2013, 22:58  [ТС]     Работа со связанным списком (смена двух чисел местами в списке) #6
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
тебе это случайно не для сортировки пузырьком надо? Ща напишу. Просто в общем случае придётся рассматривать несколько вариантов: когда элементы подряд идут, когда не подряд...
мне главное что бы получилось переставить два элемента в связанном списке местами....
Yandex
Объявления
01.03.2013, 22:58     Работа со связанным списком (смена двух чисел местами в списке)
Ответ Создать тему
Опции темы

Текущее время: 08:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru