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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Наследование,порождение объектов http://www.cyberforum.ru/cpp-beginners/thread912028.html
Помогите,пожалуйста.Задача состоит в том,что даны точка->квадрат->параллелограмм одно порождается от другого.Point-точка,Kv-квадрат,Par-пар-м.У точки изначально присутствуют две координаты.Нужно добавить св-ва квадрата и пар-ма,как это сделать я не совсем догоняю. у квадрата появится длина и высота,а у пар-ма угол.Подскажите #include "stdafx.h" class Point{ public: double x; double y;
C++ Отладка порожденного процесса Очень сильно не хватает эрудированности по этой теме. Делаю вот так: Пытаюсь запустить CreateProcess'ом процесс, процесс запускается, лезу в Attach to Process и, к сожалению, вижу порождённый процесс, но серого цвета, не могу его выделить (т.е. выделить могу, не могу подтвердить). Я подозреваю, что при собирании дочернего процесса я где-то не поставил галочку или не переключил режимы, для... http://www.cyberforum.ru/cpp-beginners/thread912022.html
C++ Добавление кнопок в диалоговое окно
программа: моделирование идеального газа" Можно ли в проекте Win32 вообще добавить кнопки? Есть в нем конструктор как в с#? Нужно поместить 3 кнопки, изменение размера шариков, цвета, и скорости // Идеальный газ.cpp: определяет точку входа для приложения. // #include "stdafx.h"
C++ Вычисление суммы первых n членов последовательности
Здравствуйте! Помогите пожалуйста помочь написать программу, очень надо! Вычисление суммы первых n членов последовательности. Пользователь вводит натуральное число n. Программа рассчитывает и выводит на экран сумму первых n членов последовательности (1/i)ni=1. Примечание: Все операции производятся в функции main(). Начиная с этого раздела, во всех дальнейших задачах необходимо...
C++ Работа с файлами (создать файл путь к которому уже задан, а вот имя хранится в переменной) http://www.cyberforum.ru/cpp-beginners/thread912000.html
Проблема: Необходимо создать файл путь к которому уже задан, а вот имя хранится в переменной. string name; cout<<"Введите имя файла: "; cin.sync(); getline(cin,name); ofstream file(name);//необходимо указать путь в конкретную папку
C++ сравнить матрицы есть функция для нахождения суммы элементов главной диагонали матрицы: int i, s=0; for(i=0; i<summa.m; i++) s+=summa.p_m; а нужно сравнить 12 матриц и у той, у которой сумма будет больше произвести там дальнейшие операции, то как их можно сравнить? я сделал вот так: if (sum (AB) > max) max = sum (AB); if (sum (BA) > max) max = sum (BA); if (sum (AC) > max) max = sum (AC); подробнее

Показать сообщение отдельно
el_gato_de_Ch
35 / 35 / 1
Регистрация: 28.04.2013
Сообщений: 110

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

25.06.2013, 23:06. Просмотров 322. Ответов 0
Метки (Все метки)

Всем привет.

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

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 и явно её вызывать при удалении элемента??
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 03:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru