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

класс список - C++

Восстановить пароль Регистрация
 
el_gato_de_Ch
35 / 35 / 1
Регистрация: 28.04.2013
Сообщений: 110
25.06.2013, 23:06     класс список #1
Всем привет.

В качестве задания было необходимо реализовать односвязный список. И вот в итоге что получилось:

my_list.h
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
#ifndef _MY_LIST_H_
#define _MY_LIST_H_
 
#include <cstdlib>
 
struct node
{
    int value;
    node* next;
    
    node(int v = 0)
    {
        value = v;
        next = NULL;
    }
};
 
class my_list
{
    int s;
    node *head;
    node *cur;
    
    public :
    my_list();
    ~my_list();
    
    void goto_head(void);
    void goto_next(void);
    void remove(int);
    void add(int);
    
    int cur_val(void);
    int size(void);
 
    private:
    my_list(const my_list&) = delete;
  my_list& operator = (const my_list&) = delete;
};
 
#endif
my_list.cpp

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 "my_list.h"
 
my_list::my_list()
{
    s = 0;
    
    cur = new node;
    head = cur;
}
 
my_list::~my_list()
{
    if(head != cur) 
        delete cur;
    
    delete head;
}
 
void my_list::add(int val)
{
    node *n = new node(val);
    
    cur->next = n;
    cur = n;
    
    ++s;
}
 
void my_list::remove(int pos)
{
    goto_head();
    
    if(!pos)
    {
        cur = cur->next;
        head->next = cur;
 
        --s;
        return;
    }
 
    for(int i = 0; i < pos - 1; ++i)
        cur = cur->next;
        
    cur->next = (pos == s - 1) ? NULL : cur->next->next;
        
    --s;
}
 
int my_list::cur_val()
{
    return cur->value;
}
 
void my_list::goto_next()
{
    cur = cur->next;
}
 
void my_list::goto_head()
{
    cur = head->next;
}
 
int my_list::size(void)
{
    return s;
}
В целом функции добавления и удаления элемента из списка работают. Однако, у меня есть просьба посмотреть на реализацию и выявить её ошибки, возможно, можно было проще сделать метод удаления элемента. К тому же у меня закрадывается подозрение что при удалении элементов из списка образуются утечки памяти, как этого избежать, реализовать деструктор у структуры node и явно её вызывать при удалении элемента??
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.06.2013, 23:06     класс список
Посмотрите здесь:

C++ класс-список
C++ Класс Линейный Список.
Класс типа двусвязный список C++
Определить класс список C++
C++ Определить класс список элементов
C++ Создать базовый класс список
C++ Класс: двунаправленный список
C++ Класс Односвязный список

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

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

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