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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Удаление нужной строчки из файла http://www.cyberforum.ru/cpp-beginners/thread796267.html
Здравствуйте. Подскажите пожалуйста, как удалить нужную строчку из файла? Строчка является ключом. Например: Содержание файла: line1=4 line2=1
C++ Контейнер map ? Не совсем удается разобраться Не удается разобраться с ассоциативными контейнерами ! Как выглядит объявление функции в псевдокоде? Что делает std::less<T> ? http://www.cyberforum.ru/cpp-beginners/thread796266.html
Ячейка заполненной строки не перезаписывается C++
Есть массив со строкой. Одну из его ячеек необходимо перезаписать, но этого не получается. Используемое ПО - Visual Studio 2008 (версию по-новее просто не потянет комп ( ). Код (я его предельно...
C++ Дан текст из цифр и строчных латинских букв, за которым следует точка
Дан текст из цифр и строчных латинских букв, за которым следует точка. Определите какие буквы- гласные (A,E,I,O,u)или согласных-больше в этом тексте.
C++ Даны координаты вершин много угольника http://www.cyberforum.ru/cpp-beginners/thread796246.html
Даны координаты вершин много угольника (x1,y1,x2,y2,...,x10,y10).Напишите программу для вычисления его перемитра (вычисление расстояния между вершинами оформить подпрограммой.
C++ Вычислить Вычислить Z=(x+y)/(k*n),где x и k- сумма и количетсвоположительных элементов массива А(40), где y и n - сумма и количество отрицательных элементов массива B(50). Определение суммы и количества... подробнее

Показать сообщение отдельно
KostyaKulakov
Заблокирован

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

27.02.2013, 19:00. Просмотров 1358. Ответов 2
Метки (Все метки)

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. мб есть у кого идеи?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru