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

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

Войти
Регистрация
Восстановить пароль
 
кщтеук34
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 70
#1

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

01.03.2013, 21:06. Просмотров 467. Ответов 5
Метки нет (Все метки)

Не могу сделать смену двух чисел местами в списке, я уже писал но так и никто путного не написал.
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;
 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.03.2013, 21:06
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Работа со связанным списком (смена двух чисел местами в списке) (C++):

Работа с двусвязным списком, поиск и перемена местами двух элементов в списке - C++
Здравствуйте! Есть список List http://pastebin.com/tNSztz50 Не могу разобраться, как найти элемент в списке по его значению, и как...

Хеш таблица со связанным списком STL - C++
Добрый день. Подскажите пожалуйста как реализуется хеш таблица со связанным списком в stl

Смена в памяти значений двух целых чисел. - C++
БИЛЕТ №16 3. Напишите программу, в которой используется функция change меняющая местами в памяти компьютера значения двух целых чисел....

В списке целых чисел поменять местами max элемент и min элемент - C++
Помогите написать эту программу на С++.

Определить максимальные элементы в каждом из двух массивов вещественных чисел, и поменять их местами - C++
Заданы два одномерных массива действительных чисел.Определить максимальные элементы в каждом массиве и поменять их местами

Смена местами чисел в массиве - C#
Задача звучит так: Трудность, для меня заключается в том, что я не могу понять как во второй кнопке объявить функцию, да и вообще с...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
m1Rr0r
247 / 230 / 15
Регистрация: 05.02.2010
Сообщений: 3,256
Завершенные тесты: 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
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,925
Записей в блоге: 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
Сообщений: 70
01.03.2013, 22:43  [ТС] #4
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
что-то не верится, что это сработает.

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

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

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

можно подумать, они не равны до этого были.
подскажи как надо?
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,925
Записей в блоге: 1
01.03.2013, 22:55 #5
Цитата Сообщение от кщтеук34 Посмотреть сообщение
подскажи как надо?
тебе это случайно не для сортировки пузырьком надо? Ща напишу. Просто в общем случае придётся рассматривать несколько вариантов: когда элементы подряд идут, когда не подряд...
кщтеук34
1 / 1 / 0
Регистрация: 27.02.2013
Сообщений: 70
01.03.2013, 22:58  [ТС] #6
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
тебе это случайно не для сортировки пузырьком надо? Ща напишу. Просто в общем случае придётся рассматривать несколько вариантов: когда элементы подряд идут, когда не подряд...
мне главное что бы получилось переставить два элемента в связанном списке местами....
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.03.2013, 22:58
Привет! Вот еще темы с ответами:

Создать связанный список из записей, содержащих сведения о журналах, реализовать операции со связанным списком - Turbo Pascal
Создать связанный список из записей, содержащих сведения о журналах (индекс, наименование, цена), реализовать операции со связанным...

Дан список чисел. Определите, сколько в этом списке элементов, которые больше двух своих соседей и выведите ко - Turbo Pascal
Дан список чисел. Определите, сколько в этом списке элементов, которые больше двух своих соседей и выведите количество таких элементов. ...

Значение поля со списком отсутствует в списке - MS Access
Здравствуйте! На форме есть поля, например, ф,и,о, район, должность. Значения полей со списком &quot;район&quot; и &quot;должность&quot; берутся из...

Смена подстановочной таблицы в поле со списком - MS Access
Может быть, кто то - из опытных Acess-мастеров, подскажет, как можно реализовать следующую функцию: 1.Есть форма 'Main' 2.Есть на...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
01.03.2013, 22:58
Ответ Создать тему
Опции темы

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