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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Mr. Pyatachok
8 / 8 / 0
Регистрация: 30.06.2011
Сообщений: 250
#1

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

06.05.2012, 01:36. Просмотров 429. Ответов 0
Метки нет (Все метки)

Ребята, здравствуйте!!!
Помогите дописать код:
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, (сдвиг вправо, сдвиг влево на заданное колчисевто битов).

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

В чем ошибка? В массиве целых чисел найти количество максимальных элементов - C++
#include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; #define N 16 #define A 0 #define B 5 void Init(int *a, int n) { ...

Задана матрица целых чисел A(n,n). Все элементы столбца, с наибольшим номером, среди тех, где находится более двух простых элементов, заменить разно - C++
Задана матрица целых чисел A(n,n). Все элементы столбца, с наибольшим номером, среди тех, где находится более двух простых элементов,...

Числа считаются равными если они отличаются не более, чем на (10^-12) / c++ / как реализовать эту возможность? - C++
На плоскости заданы три точки А, В и С. Определить, какая из двух последних точек (B или C) расположена ближе к A, и вывести расстояние от...

Сортировка 5 чисел не более чем за 7 сравнений - C++
Даны 5 попарно различных целых чисел. Упорядочить их по возрастанию, используя для этого не более 7 сравнений. Заранее благодарю!!!!

В массиве из 10 целых чисел подсчитать сумму элементов более чем в 2 раза превышающих минимальный - Pascal
Помогите написать программу: В массиве из 10 целых чисел подсчитать сумму элементов более чем в 2 рах превышающих минимальный.

Реализовать класс больших целых чисел - C#
Необходимо реализовать класс больших целых чисел. Так как в типах int и long нет возможности хранить очень большие числовые значения,...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.05.2012, 01:36
Привет! Вот еще темы с ответами:

Сколько существует целых чисел в диапазоне от 0 до 100 000, содержащих не более чем две цифры «7»? - Комбинаторика
Здравствуйте, форумчане и гуру дискретной математики) В общем, вопрос уже есть в заголовке, повторю его для СЕО оптимизации и вашего...

Сколько существует целых чисел в диапазоне от 0 до 100 000, содержащих не более чем две цифры «8»? - Комбинаторика
Привет помогите с задачей! Сколько существует целых чисел в диапазоне от 0 до 100 000, содержащих не более чем две цифры «8»? Я...

Реализовать класс Set - C#
Реализовать класс Set не более чем из 256 элементов – символов. Решение должно обеспечивать включение элемента в множество, исключение...

В массиве целых чисел найти произведение второго и четвертого элементов, значения которых более 3 - Pascal ABC
В массиве целых чисел найти произведение второго и четвертого элементов, значения которых более 3.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru