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

Двусвязный список (укажите на недоработки в моем коде) - C++

Восстановить пароль Регистрация
 
kolit
1 / 1 / 0
Регистрация: 02.06.2012
Сообщений: 10
03.06.2012, 13:52     Двусвязный список (укажите на недоработки в моем коде) #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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include <iostream>
 
using namespace std;
/* структура представляет узел списка*/ 
struct Node 
{
    int Data;
    Node *Next;
    Node *Prev;
};
/*класс представляет связный список*/
class MyLinkedList{
    Node *Begin;    //начало и конец списка
    Node *End;  
 
public:
    int PushBack(int Data);//добавить элемент
    int DataOut();//вывести на монитор для упрощения не используем oprator <<
    int Free();//очистить список
 
    MyLinkedList();//конструктор
    ~MyLinkedList(){Free();};
 
};
int main(){
    /*пример работы со списком */
    MyLinkedList Test;// создаем объект типа связный список
    
    for(int i = 0;i<10;i++)
        Test.PushBack(rand()%25);//добавляем элементы в список
    Test.DataOut();//выводим на монитор
 
    system("pause");
    return 0;
}
 
//чтоб упростить задачу используем два пустых элемента
MyLinkedList::MyLinkedList(){
    Begin=new Node;
    End=new Node;
    /* связуем два элемента в месте*/
    Begin->Next= End;
    Begin->Prev=NULL;
    End->Next=NULL;
    End->Prev=Begin;
}
 
/*добавления в конец списка нового элемента*/
int MyLinkedList::PushBack(int data){
    Node *Add = new Node;//создали новый элемент 
    Add->Data=data;//заполнили поя
 
    /*связали елемент со списком*/
    Add->Prev=End->Prev;
    Add->Next=End;
    
    End->Prev->Next=Add;
    End->Prev=Add;
 
    return 0;
}
 
/*Вывод списка на монитор*/
int MyLinkedList::DataOut(){
    Node *tmp=Begin->Next;//элемент который выводим 
 
    while(tmp != End){//пока не дошли до конца 
        cout<<tmp->Data<<'\t';
        tmp=tmp->Next;//к след элементу
    }
    cout<<endl;
    return 0;
}
/*Очистка списка */
int MyLinkedList::Free(){
    Node *tmp ;
 
    while(Begin!=NULL){
        tmp=Begin;
        Begin=Begin->Next;//переходим к след 
        delete tmp;// удаляем предыдущий
    }
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.06.2012, 13:52     Двусвязный список (укажите на недоработки в моем коде)
Посмотрите здесь:

Двусвязный список C++
Переделать двусвязный список в двусвязный кольцевой C++
C++ Подскажите что не в моем коде(Сортировка слиянием)
C++ двусвязный список
Что не так в моем коде? C++
Двусвязный список (в конец двусвязного списка добавить другой список) C++
C++ Подскажите, что мне надо поменять в моем коде, чтобы найти сумму по столбцам?
Сформировать список из 10 работников, используя динамическую структуру данных двусвязный список C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Jupiter
Каратель
Эксперт C++
6542 / 3962 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
03.06.2012, 14:01     Двусвязный список (укажите на недоработки в моем коде) #2
объявлять Node вне класса не имеет смысла

Цитата Сообщение от kolit Посмотреть сообщение
int DataOut();//вывести на монитор для упрощения не используем oprator
<<
а если завтра потребуется вывести в файл?

Цитата Сообщение от kolit Посмотреть сообщение
int PushBack(int Data);//добавить элемент
возврат значения излишен
дальше не смотрел
Yandex
Объявления
03.06.2012, 14:01     Двусвязный список (укажите на недоработки в моем коде)
Ответ Создать тему
Опции темы

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