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

Не работает е моим деструктором, только с дефолтовым - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Площадь треугольника и круга http://www.cyberforum.ru/cpp-beginners/thread123439.html
Здравствуйте Прошу помочь с написанием программы: Из заданного на плоскости множества точек выбрать три различные точки так, чтобы разность между площадью круга,проходящей через эти три точки , и площадью треугольника с вершиной в этих точках была равна нулю или меньше определённого вводимого параметра(с которым выводились все комбинации этих точек). Что то пытался сделать, но...
C++ Как найти все вершины, достижимые из заднной??? Доброго всем дня. прошу помощи или советов в реализации задачи типа: задан орграф: 1) найти все вершины, недостижимые из заданной, 2) найти все вершины, достижимые из заднной за указанное число шагов. в интернете не нашла ни одного алгоритма осуществляющего поиск всех возможных путей из одной точки( хотя может просто плохо искала( если у кого то есть возможность помочь - очень прошу,... http://www.cyberforum.ru/cpp-beginners/thread123430.html
C++ Дана квадратная матрица
Дана квадратная матрица,NxN.Определить: 1)произведение элементов в тех строках,которые не содержат отрицательных элементов. 2)максимум среди сумм элементов диагоналеи параллельных главной диагонали.
Двумерные массивы C++
Привет всем! если есть у кого время, посмотрите что можно сделать, нужна ваша помощь! Сформировать одномерный массив B из максимальных элементов столбцов прямоугольной матрицы A. В массиве B поменять местами первый отрицательный и последний положительный элементы! начал тут: #include <stdio.h> #include <conio.h> #include <stdlib.h> void main() { const int N1=10,M1=10;//Max razmer...
C++ Ошибка в вызове функции http://www.cyberforum.ru/cpp-beginners/thread123406.html
Учителя толком не могут обьяснить в чем ошибка, объясните pls =( #include <iostream.h> void vvod(int r,int,int); int matr(int,int,int); int a,b; int main() {
C++ Прокомментировать код #include <stdio.h> #include <conio.h> #include <stdlib.h> #include <iostream.h> #include <string.h> #include <math.h> main() { clrscr(); int a,b,n,i,j,x; подробнее

Показать сообщение отдельно
IIGoshaII
8 / 8 / 1
Регистрация: 20.03.2010
Сообщений: 57

Не работает е моим деструктором, только с дефолтовым - C++

29.04.2010, 13:12. Просмотров 736. Ответов 16
Метки (Все метки)

Что именно делает деструктор который по умолчанию?
Просто есть код, который работает только если деструктор используется именно дефолтовый.
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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
class mnozh
{
    int n;
    int *mas;
    public:
    mnozh(); // конструктор
    mnozh(int); // конструктор по умолчанию
    mnozh(mnozh&); // конструктор копирования
    ~mnozh(); // Деструктор
    friend const mnozh& operator +(const mnozh& , int) ; // добавка одного элемента 
    mnozh& operator =(const mnozh&); //перегрузка операции присваивания
};
 
 
mnozh::mnozh() // Конструктор
{
    int i,k,j,z;
    cout << "Vvedite kolichestvo elementov \n n=";
    cin >> k;
    n=0;
    mas = new int[k];
    for(i=0;i<k;i++)
    {
        cout << "Vvedite " << i << " element:  ";
        cin >> mas[i];
        z=0;
        for(j=0;j<i;j++)
        {
            if(mas[j]==mas[i])
            {
 //               cout << mas[i] << "==" << mas[j] << "    " << z << "\n";
                z++;
            }
        }
        if(z!=0)
        {
            i--;
            k--;
            cout << "povtor \n";
        }
    }
    n=k;
};
 
mnozh::mnozh(int x) // Конструктор
{
    int i;
    if(x>=0)
    {
        mas = new int[x];
        n=x;
        for(int i=0;i<x;i++)
        {
            mas[i]=i+1;
        }
    }
    else
    {
        cout << "x < 0";
    }
   // cout << "J sozdatel'";
};
 
mnozh::mnozh(mnozh & p) // конструктор копирования
{
    int i;
   // cout << "I am copy " << p;
    //cout << "n="<<n<<"; p.n="<<p.n<<"  ";
    n=p.n;
   // cout << "  posle, n="<<n;
    mas = new int[n];
     for(i=0;i<n;i++)
    {
       // cout << "   mas[" << i << "] = " << mas[i] << " = p.mas[" << i << "] = " << p.mas[i] << "  ";
        mas[i]=p.mas[i];
       // cout << "  posle, mas["<<i<<"]="<<mas[i];
    }
};
 
mnozh::~mnozh() //Деструктор
{
    delete mas;
};
 
const mnozh& operator +(const mnozh & p, int x)// добавка одного элемента
{
    mnozh viv(1);
    viv=p;
    int i;
    if (viv.prov(x))
    {
        viv.n++;
        viv.mas = new int[viv.n];
        for(i=0;i<viv.n-1;i++)
        {
            viv.mas[i] = p.mas[i];
        }
        viv.mas[i] = x;
    }
    else
    {
        cout << "Chislo x=" << x << " uzhe est' v mnozhestve";
    }
    cout << viv;
    return viv;
};
 
 
mnozh& mnozh::operator =(const mnozh & p) //Операция присваивания
{
    int i;
    if(&p != this)
    {
        //cout << "prisvaivaem massivu dlinni " << n << " so znach " << *this << " , massiv dlinni " << p.n << " so znach " << p;
   //     cin >> i;
        n=p.n;
        mas = new int[n];
        for(i=0;i<n;i++)
        {
            mas[i]=p.mas[i];
        }
    return *this;
    }
    else
    {
        cout << "hernj";
    }
};
и есть сам мэйн

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include "mnozh.h"
 
main()
{
    int k;
    mnozh ed;
    mnozh cd(5);
    cout << "\n" << ed;
    cout << "\n" << cd;
    cd = (ed + 1);
    cout << "\n";
    cout << "\n" << ed;
    cout << "\n" << cd;
    return 0;
}
Прога создает класс множество, прибавление элемента соответственно прибавляет элемент, если его еще нет. Ну вот хоть убей не могу понять почему работает только с дефолтовым деструктором =(
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru