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

Односвязные списки - C++

Восстановить пароль Регистрация
 
aalexander
 Аватар для aalexander
0 / 0 / 0
Регистрация: 22.12.2013
Сообщений: 17
22.12.2013, 22:58     Односвязные списки #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
#include "stdafx.h"
#include "iostream"
 
using namespace std;
 
struct Single_List 
{
    int Data; //информационное поле
    Single_List *Next; //адресное поле
};
 
int n=5, mas[]={5,3,1,2,4};
Single_List *Head; //указатель на первый элемент списка
Single_List *Current; //указатель на текущий элемент списка (при необходимости)
 
 
//создание однонаправленного списка (добавления в конец)
void Make_Single_List(int n, Single_List **Head)
{   
  if (n > 0) 
  {
    (*Head) = new Single_List();
    //выделяем память под новый элемент
    cout << "Введите значение: "; //8, 6, 4, 5, 7
    cin >> (*Head)->Data;
    //вводим значение информационного поля
    (*Head)->Next=NULL;//обнуление адресного поля
     Make_Single_List(n-1,&((*Head)->Next));
  }
}
 
//печать однонаправленного списка
void Print_Single_List(Single_List *Head) 
{
  if (Head != NULL) 
  {
    cout << Head->Data << "\t";
    Print_Single_List(Head->Next);
    //переход к следующему элементу
  }
  else cout << "\n";
}
 
//освобождение памяти, выделенной под однонаправленный список
void Delete_Single_List(Single_List* Head){
  if (Head != NULL)
  {
    Delete_Single_List(Head->Next);
    delete Head;
  }
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale (LC_ALL, "Rus");
    Make_Single_List(n, &Head);
    cout<<endl;
    cout<<"Спиоск:"<<endl;
        // "перестройка"
    Print_Single_List(Head);
    Delete_Single_List(Head);
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.12.2013, 22:58     Односвязные списки
Посмотрите здесь:

односвязные списки C++
C++ Односвязные списки
Односвязные списки C++
Односвязные списки C++
C++ Односвязные списки С++
Односвязные списки C++
односвязные списки С++ C++
C++ Односвязные списки

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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