SET THEORY, Dynamic Memory

I need to do the following:

create a union method (i.e. union(set)) that creates a union for two sets. This method should somehow invoke the elements method, a method whose specifications are mentioned below
element (int) that checks if the elements are a part of the set, I have a method below, but I am not sure if it's right. Furthermore, this boolean member function is supposed to be used in my union function to check elements to ensure that elements of Set B, for example, would not be in Set A. I am very unsure how to use this method

I understand that there is a set in the standard library, but we are not required to use it

I attempted to create a union function, but I was unsuccessful because I am unsure how to return a particular object
If you could address at least one of these, i would greatly appreciate it, I am really struggling to understand how to address these specifications. Thanks so much for your help!

* I understand that there is a set in the standard library, but we are not required to use it

If you could address at least one of these, i would greatly appreciate it, I am really struggling to understand how to address these specifications. Thanks so much for your help!

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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
#ifndef SET_H
#define SET_H

    #include <iostream>
    #include <cstdlib>
    #include <iomanip>

    using namespace std;

    class Set{

            friend ostream &operator<< ( ostream &, const Set &);
            friend istream &operator>> ( istream &, Set &);

            public:

                    Set ( int = DEFAULTSIZE ); //default constructor
                    Set ( const Set & ); //copy constructor
                    Set ( int [], int, char ); //constructor passing array of integers, size, name of set

                    ~Set(); //destructor

                    //assignment operator
                    const Set &operator= ( const Set &);
                    //equality operator
                    bool operator== ( const Set & ) const;
                    //inequality operator
                    bool operator!= ( const Set &s1) const{
                            return !(*this == s1);
                    }
                    //subscript operators
                    int &operator[] ( int );
                    int operator[] ( int ) const;

                    //methods to find union, intersection, and difference of sets
                    Set Union ( Set & );
                    Set Intersect ( Set & );
                    Set Difference ( Set & );

                    Set operator+ ( Set & ); //to represent union of two sets
                    Set operator^ ( Set & ); //to represent intersection of two sets
                    Set operator- ( Set & ); //to represent difference between two sets

                    bool element ( int );

            private:
                    static const int DELIM = -999; // delimiter to signal end of input
                    static const int DEFAULTSIZE = 10;
                    int numOfElements;
                    int psize; //physical size of array
                    int *set; //pointer array to represent set

    };
    #endif

    //SOURCE FILE

    //default constructor
    Set::Set ( int s ){

            if ( s > 0 )
                    psize = s;
            else
                    psize = DEFAULTSIZE;
            //allocate an array of specified size
            set = new int[ psize ];

            if(!set) {
                    //send an error is system cannot allocate memory
                    cout << "Cannot Allocate Memory, exiting program... " << endl;
                    exit (1);
            }

            for ( int i = 0; i < psize; i++){
                    set[i] = 0;
                    numOfElements = 0;
            }

    }

    //copy constructor
    Set::Set ( const Set &setToCopy): psize(setToCopy.psize){
            set = new int[psize];
            if(!set){
                    cout << "Cannot Allocate Memory, exiting program..." << endl;
                    exit (1);
            }
            for (int i = 0; i < psize; i++ ){
                    set[i] = setToCopy.set[i];

                    numOfElements = psize;
            }
    }

    Set::~Set(){
            if (set)
                    delete [] set;
            set = NULL;
    }

    const Set &Set::operator= ( const Set &s1 ){
            if ( &s1 != this){
                    if (numOfElements != s1.numOfElements){
                            delete [] set;
                            psize = numOfElements;
                            set = new int [psize];
                            if (!set){
                                    cout << "Cannot Allocate memory, exiting program..." << endl;
                                    exit (1);
                            }
                    }
            }
            //assign contents of the array on the right to the contents of the array on the left
            for ( int i = 0; i < psize; i++ ){
                    set[i] = s1.set[i];
                    numOfElements = psize;
            }

            return (*this);
    }

    bool Set::operator== ( const Set &s1 ) const {
            bool validate = true;

            if ( numOfElements == s1.numOfElements ){
                    for ( int i = 0; i < numOfElements; i++){
                            if ( set [i] != s1.set[i] ){
                                    validate = false;
                                    break;
                            }
                    }
            }

            return (validate);
    }

    int &Set::operator[]( int subscript ){
            if ( subscript < 0 || subscript >= psize ) {
                    cout << " Error, exiting program... " ;
                    exit (1);
            }

            return set[subscript];
    }
    void Set::input(){

            int ival;

            cout << "Enter up to 10 numbers or type in the delimiter -999" << endl;

            for ( int i = 0; i < psize; i++){
                    cin >> ival;
                    if ( ival != Set::DELIM ){
                            set [i] = ival;
                    }
                    else {
                            numOfElements = i;
                            break;
                    }
            }
    }
    void Set::display(){
            for ( int i = 0; i < numOfElements; i++ ){
                    cout << set[i] << endl;
            }
            cout << "Physical Size is " << numOfElements << endl;
    }
    bool Set::element ( int n ) {
            bool validate = true;
            for ( int i = 0; i < psize; i++){
                    if ( set[i] == n )
                            validate = false;
            }
            return (validate);
    }

    Set Set::Union( Set &B ){
            const int newsize = B.psize + psize;
            Set c(newsize);
            for ( int i = 0; i < psize; i++){
                    C.set[i] = set[i];
            }
            for ( int i = psize; i < newsize; i++){
                    for ( int j = 0; j < B.psize; j++){
                            C.set[i] = B.set[j];
                    }
            }
            return (c.set); //I NEED TO RETURN THE SET OF C SOMEHOW
    }

    main (){

            Set A, B, C;
            A.input();
            A.display();
            B.input();
            B.display();
            A.Union(B);
            A.display();

    }                                                                                                                                                     
Last edited on
Topic archived. No new replies allowed.