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

Реализовать класс Set не более чем из 64 элементов целых чисел - C++

Восстановить пароль Регистрация
 
Mr. Pyatachok
 Аватар для Mr. Pyatachok
8 / 8 / 0
Регистрация: 30.06.2011
Сообщений: 250
06.05.2012, 01:36     Реализовать класс Set не более чем из 64 элементов целых чисел #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
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
#include<conio.h>
#include<iostream.h>
 
class Arrays
{       private:
    static const unsigned int k=4;
    static const unsigned int q=8;
    unsigned long m1[k];
    unsigned long m2[k];
    unsigned long m[q];
    unsigned long mass_and_or_xor[k];
    int i;
    int number_of_bits;
    char answer;
        public:
    Arrays()
    {
        for(i=0;i<k;++i)
        m1[i]=m2[i]=0;
    }
    void Display();
    int Init_Array1();
    int Init_Array2();
    void String();
    void Question();
    void LeftShift();
    void RightShift();
    void Array_AND();
    void Array_OR();
    void Array_XOR();
};
 
void Arrays::Array_XOR()
{
    for(i=0;i<k;i++)
    {
        if(m1[i]!=m2[i])
        {
          mass_and_or_xor[i]=1;
        }
        else mass_and_or_xor[i]=0;
    }
    cout<<"The result of 'XOR' operation: "<<endl;
    for(i=0;i<k;i++)
    {
        cout<<mass_and_or_xor[i];
    }
}
 
void Arrays::Array_OR()
{
    for(i=0;i<k;i++)
    {
        if(m1[i]==1||m2[i]==1)
        {
          mass_and_or_xor[i]=1;
        }
        else mass_and_or_xor[i]=0;
    }
    cout<<"The result of 'OR' operation: "<<endl;
    for(i=0;i<k;i++)
    {
        cout<<mass_and_or_xor[i];
    }
}
 
void Arrays::Array_AND ()
{
    for(i=0;i<k;i++)
    {
        if(m1[i]==m2[i])
        {
          mass_and_or_xor[i]=m1[i];
        }
        else mass_and_or_xor[i]=0;
    }
    cout<<"The result of 'AND' operation: "<<endl;
    for(i=0;i<k;i++)
    {
        cout<<mass_and_or_xor[i];
    }
}
 
void Arrays::LeftShift()
{
    cout<<"Please, insert the number of LeftShift bits ";
    cin>>number_of_bits;
    for(i=0;i<q-number_of_bits; i++)
    {
        m[i]=m[i+number_of_bits];
    }
    for(i=q-number_of_bits;i<q;i++)
    {
         m[i]=0;
    }
}
 
void Arrays::RightShift()
{
    cout<<"Please, insert the number of RightShift bits ";
    cin>>number_of_bits;
    for(i=0;i<number_of_bits; i++)
    {
        m[i]=0;
    }
    for(i=number_of_bits;i<q;i++)
    {
        m[i]=m[i-number_of_bits];
    }
}
 
void Arrays::Display()
{
    for(i=0;i<q;++i)
    cout<<m[i];
}
 
int Arrays::Init_Array1()
{
    cout<<"Please, insert elements of the first massive"<<endl;
    for(i=0;i<k;++i)
    {
        cout<<"Insert "<<i<<"-j element ";
        cin>>m1[i];
    }
    cout<<endl;
}
 
int Arrays::Init_Array2()
{
    cout<<"Please, insert elements of the second massive"<<endl;
    for(i=0;i<k;++i)
    {
        cout<<"Insert "<<i<<"-j element ";
        cin>>m2[i];
    }
    cout<<endl;
}
 
void Arrays::String()
{
    for(i=0;i<k;i++)
    {
         m[i]=m1[i];
    }
    for(i=k;i<q;i++)
    {
        m[i]=m2[i-k];
    }
}
 
void Arrays::Question()
{
    for(;;)
    {
        cout<<endl<<"Do you want any operation? (Y/N)"<<endl;
        cin>>answer;
    switch(answer)
    {
        case 'N': break;
        case 'Y': cout<<"For 'LeftShift', Press 1"<<endl;
                  cout<<"For 'RightShift', Press 2"<<endl;
                  cout<<"For 'And', Press 3"<<endl;
                  cout<<"For 'Or', Press 4"<<endl;
                  cout<<"For 'Xor', Press 5"<<endl;
                  cin>>answer;
                  cout<<endl;
    }
    switch(answer)
    {
        case '1': LeftShift(); Display(); break;
        case '2': RightShift(); Display(); break;
        case '3': Array_AND (); break;
        case '4': Array_OR (); break;
        case '5': Array_XOR (); break;
        break;
    }
     break;
    }
}
 
int main()
{
    Arrays P;
    P.Init_Array1();
    P.Init_Array2();
    P.String();
    P.Display();
    P.Question();
    getch();
    return 0;
}
Вот само задание:
Реализовать класс Set не более чем из 64 элементов целых чисел, используя класс Array. Множество должно обеспечивать включение элемента в множество, исключение элемента из множества, объединение, пересечение и разность множеств, вычисление количества элементов в множестве.

Собственно класс Array демонтсрирует работу с битами: and, or, xor, not, (сдвиг вправо, сдвиг влево на заданное колчисевто битов).

Заранее всем спасибо кто откликнулся.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.05.2012, 01:36     Реализовать класс Set не более чем из 64 элементов целых чисел
Посмотрите здесь:

C++ Сортировка 5 чисел не более чем за 7 сравнений
C++ Класс целых чисел
Объявить массив не более чем 15 элементов. Вывести обратные по модулю величины и проверить изменились ли адреса элементов этих двух массивов. C++
Задана матрица целых чисел A(n,n). Все элементы столбца, с наибольшим номером, среди тех, где находится более двух простых элементов, заменить разно C++
Превышает ли максимальное из чисел последовательности минимальное не более чем на 25? C++
C++ Проверить, верно ли, что максимальное из чисел превышает минимальное не более чем на 25
Числа считаются равными если они отличаются не более, чем на (10^-12) / c++ / как реализовать эту возможность? C++
C++ В чем ошибка? В массиве целых чисел найти количество максимальных элементов

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

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

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