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

Односвязные списки (функции обращения списка) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.89
KostyaKulakov
Заблокирован
27.02.2013, 19:00     Односвязные списки (функции обращения списка) #1
1. Написать рекурсивную функцию обращения списка.
2. Написать итеративную функцию обращения списка.

:С попытался написать, так и не получилось

задание такого:

in:
9->8->7->6

out:

6->7->8->9

Добавлено через 4 часа 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
#include <iostream>
#include <vector>
#include "timer.h"
 
struct Node
{
    Node(int data)
    : data_(data)
    {}
    
    int data_; // полезная часть списка
    Node* next; // указатель на следующий элемент
};
 
Node* toList(const std::vector<int>& array); //(int array[], size_t n) создаем список из вектора
 
size_t Count(Node* list, int value); // подсчитывает количество узлов с данным значением
 
void DeleteList(Node* list); // удаляет список
 
void PrintList(Node* list); // печатает список
 
Node* prepend(Node* list, Node* node); // вставляет узел в голову, возвращает указатель на голову
 
size_t ListLength(Node* list); // длина односвязного списка
 
int main()
{
    Node* spisok[4];
 
    spisok[0] = new Node(0);
    spisok[1] = new Node(1);
    spisok[2] = new Node(2);
    spisok[3] = new Node(3);
    spisok[4] = new Node(4);
 
    for(int i =0; i < 4; ++i)
        spisok[i]->next = spisok[i+1];
 
    for(int i =0; i < 4; ++i)
        std::swap(spisok[4-i]->data_, spisok[i]->data_);
 
    PrintList(spisok[0]);
 
 
 
        
}
 
Node* toList(const std::vector<int>& array) //(int array[], size_t n) создаем список из вектора
{
    Node* list = nullptr;
    
    for (size_t i = 0; i != array.size(); ++i)
        list = prepend(list, new Node(array[i]));
    
    return list;
}
 
size_t Count(Node* list, int value) // подсчитывает количество узлов с данным значением
{
    size_t count = 0;
    
    while(list)
    {
        if (list->data_ == value)
            ++count;
        list = list->next;
    }
    
    return count;
}
 
void DeleteList(Node* list) // удаляет список
{
    while (list)
    {
        Node* next = list->next;
        delete list;
        list = next;
    }
}
 
void PrintList(Node* list)
{
    while (list)
    {
        std::cout << list->data_ << std::endl;
        list = list->next;
    }
}
 
 
Node* prepend(Node* list, Node* node) // вставляет узел в голову, возвращает указатель на голову
{
    if (node != nullptr) 
        node->next = list;
 
    return node ? node : list;   
}
 
size_t ListLength(Node* list) // длина односвязного списка
{
    size_t length = 0;
    
    while(list)
    {
        ++length;
        list = list->next;
    }
        
    return length;
}
вот в int main() с помощью не рекурсивного метода попробовал реализовать, но результат 0. мб есть у кого идеи?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.02.2013, 19:00     Односвязные списки (функции обращения списка)
Посмотрите здесь:

односвязные списки C++
Односвязные списки C++
C++ Односвязные списки С++
Списки. Функции добавление списка в конец и в середину другого списка. C++
односвязные списки С++ C++
C++ Односвязные списки
Односвязные списки: нужно ли при выходе из функции возвращать голову? C++
C++ Создать на основе класса дополнительный метод из функции main() (односвязные списки)

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
xtorne21st
интересующийся
300 / 271 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
27.02.2013, 23:48     Односвязные списки (функции обращения списка) #2
Идеи есть: в начале main вы выделяете память для 4х элементов а пытаетсь засунуть туда аж целых 5 . Ну от этого нужно начать плясать...
Tulosba
:)
Эксперт C++
4377 / 3220 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
28.02.2013, 00:44     Односвязные списки (функции обращения списка) #3
Может пригодится. Набросал что-то такое:
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
#include <iostream>
 
using namespace std;
 
struct node
{
   node* next;
   int data;
};
 
class list
{
public:
   list() : head(0){}
   
   void add( int data )
   {
      node* nd = new node();
      nd->data = data;
      nd->next = 0;
 
      if( !head ) head = nd;
      else
      {
         node* cur = head;
         while( cur->next )
         {
            cur = cur->next;
         }
         cur->next = nd;
      }
   }
   
   void print()
   {
      node* cur = head;
      while( cur )
      {
         cout << cur->data << "->";
         cur = cur->next;
      }
      cout << endl;
   }
   
   void reverse()
   {
      if( !head || !head->next ) return;
      
      node* cur = head;
      node* prev = 0;
      while( cur )
      {
         node* next = cur->next;
         cur->next = prev;
         prev = cur;
         cur = next;
      }
      
      head = prev;
   }
   
private:
   node* head;
};
 
 
int main() {
  
   list lst;
   
   lst.add( 10 );
   lst.add( 20 );
   lst.add( 30 );
   lst.add( 40 );
   
   lst.print();
   
   lst.reverse();   
   lst.print();
   
   return 0;
}
Yandex
Объявления
28.02.2013, 00:44     Односвязные списки (функции обращения списка)
Ответ Создать тему
Опции темы

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