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

C++ ООП. Создать базовый класс Array - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Проблемы с программой (найти строку с максимальным средним арифметическим элементов и сформировать матрицу) http://www.cyberforum.ru/cpp-beginners/thread793755.html
Дана матрица а,надо найти строку с максимальным средним арифметическим элементов и сформировать матрицу D,исключив из А найденную строку матрица: 1.2 2.1 .3 -8.4 6 5.2 -1.6 7.2 11.2 3.4 4.2 15.1 6.8 -7.3 10.6 -5.9 18.4 9.2 -1.6 -2.1Добавлено через 3 часа 2 минуты #include "stdafx.h" #include <iostream> #include <cstdlib>
C++ Для двух вводимых пользователем чисел, вычислить сумму их квадратов Для двух вводимых пользователем чисел, вычислить сумму их квадратов или разность их кубов в зависимости от выбранного переключателя, используя оператор выбора switchв http://www.cyberforum.ru/cpp-beginners/thread793743.html
C++ Класс String. Напечатать все слова, входящие в эту текстовую строку, имеющие такую же длину как и заданное слово
Даны текстовая строка и слово. Напечатать все слова, входящие в эту текстовую строку, имеющие такую же длину как и заданное слово. Не могу решить это задание с классом string. Помогите пожалуйста!!!
C++ перекомпиляция пакета на Си
помогите пожалуйста перекомпилировать пакет на Си upd: извините, сервер не принял файл больше 10 Мб, а я не проконтролировал... перезалил архивом из двух частей: http://bible-exodus.narod2.ru/articles/astro_ephemeris/jpl_ephemeris/scripts/mice_toolkit_n0064/mice_toolkit_n0064_for_recompilation.part1.rar ...
C++ Автоматические переменные http://www.cyberforum.ru/cpp-beginners/thread793731.html
Доброго времени суток, уважаемые форумчане! В книге Стивена Прата по С++ приводится следующий листинг: // delete.cpp -- using the delete operator #include <iostream> #include <cstring> // or string.h using namespace std; char * getname(void); // function prototype int main()
C++ Массив объектов Здравствуйте,помогите починить программу,не знаю в чем причина,мб недопонимаю.... Задание: Элементы масива которые больше 10 заменить на 1, остальные округлить до ближайшего целого. #include <iostream> #include <cmath> using namespace std; class top {int a; public: void vin (int n) {a=n;} int fal() {return if(abs(a)>10) {a=1}; ... подробнее

Показать сообщение отдельно
Leet
0 / 0 / 0
Регистрация: 05.12.2011
Сообщений: 9
24.02.2013, 16:40     C++ ООП. Создать базовый класс Array
Задание выглядит так:
Создать базовый класс Array, в котором определите полемассив подходящеrо типа и поле для хранения количества элементов у текущего объектамассива. Максимально возможный размер массива задается статической константой. Реализуйте конструктор инициализации, задающий количество элементов и начальное значение (по умолчанию О). Реализуйте методы доступа к отдельному элементу, перегpузив операцию индексирования []. При этом должна выплняться проверка Индекса на допустимость.
Реализовать один из классов заданий rлавы 2 как производный класс от класса Array; использовать открытое наследование. Во всех заданиях необходимо реализовать конструкторы инициализации и конструктор без apryMeHToB. Указанные в задании операции реализуются посредством переrpузки подходящих операций.
Во всех заданиях должны быть поддержаны соответствующие операции с присваиванием, ввод с клавиатуры, вывод на экран.
Создать класс Decimal для работы со знаковыми целыми. Знак представить отдельным полем sign.

Класс Decimal я сделал
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
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
#include <iostream>
#include <string>
#include <sstream>
using namespace std;
class TDecimal
{
   public:
      enum {SIZE = 100};
   protected:
      unsigned char val[SIZE];
      unsigned size;
      int sing;
   public:
       TDecimal(unsigned long value = 0): size(0)
      {
         *this = value;
      }
      TDecimal(const string& value): size(0)
      {
         *this = value;
      }
      TDecimal& operator = (unsigned long value);
      TDecimal& operator = (const string& value);
      unsigned operator [] (unsigned i);
      TDecimal operator + (const TDecimal& dec);
      TDecimal operator - (TDecimal& dec);
      TDecimal operator * (const TDecimal& dec);
      bool operator == (const TDecimal& dec);
      bool operator < (const TDecimal& dec);
      bool operator > (const TDecimal& dec);
      unsigned GetSize() const
      {
         return size;
      }
      friend ostream& operator << (ostream& os, const TDecimal& digit);
};
//----------------------------------------------//
TDecimal& TDecimal::operator = (unsigned long value)
{
   size = 0;
   while (value)
   {
      val[size++] = value % 10;
      value /= 10;
   }
   return *this;
}
//----------------------------------------------//
TDecimal& TDecimal::operator = (const string& value)
{
   size = value.size();
   for (unsigned i = 0; i < size; ++i)
   {
      val[i] = value[size-i-1]-48;
   }
   return *this;
}
//----------------------------------------------//
unsigned TDecimal::operator [] (unsigned i)
{
   unsigned char digit = 0;
   if (i < size)
   {
      digit = val[size-i];
   }
   return digit;
}
//----------------------------------------------//
TDecimal TDecimal::operator + (const TDecimal& dec)
{
   TDecimal result;
   unsigned mod = 0;
   result.size = (size < dec.size) ? dec.size : size;
   for (unsigned i = 0; i < result.size; ++i)
   {
      result.val[i] = val[i] + dec.val[i] + mod;
      mod = result.val[i] / 10;
      result.val[i] %= 10;
   }
   if (mod)
   {
      result.val[result.size++] = 1;
   }
   return result;
}
unsigned difference (unsigned char *x1,unsigned char *y1, unsigned char *z1, int length,int n,int n1)
{
int x[100],y[100],z[100];
for (int i=0; i<100; i++){x[i]=0; y[i]=0;z[i]=0;} 
for (int i=n-1; i>=0; i--) {x[i]=(int)x1[i]; }
for (int i=n1-1; i>=0; i--) {y[i]=(int)y1[i]; }
    for (int ix = 0; ix < (length - 1); ix++) // проход по всем разрядам числа, начиная с последнего, не доходя до первого
    {
        if (ix < (length - 1)) // если текущий разряд чисел не первый
        {
            x[ix + 1]--; // в следующуем разряде большего числа занимаем 1.
            z[ix] += 10 + x[ix]; // в ответ записываем сумму значения текущего разряда большего числа и 10-ти
 
        } else  // если текущий разряд чисел - первый
                z[ix] += x[ix]; // в ответ суммируем значение текущего разряда большего числа
 
        z[ix] -= y[ix]; // вычитаем значение текущего разряда меньшего числа
 
        if (z[ix] / 10 > 0) // если значение в текущем разряде двухразрядное
        {
            z[ix + 1]++; // переносим единицу в старший разряд
            z[ix] %= 10; // в текущем разряде отсекаем ее
        }
    }
    for (int i=99;i>=0;i--) z1[i]=(unsigned)z[i];
    return 0;
}
TDecimal TDecimal::operator-(TDecimal& dec)
{
   TDecimal result;
   int k;
   result.size=size;
   if (size > dec.size)
{
    result.size = size;
    k = 1; // если к == 1, значит первое число длиннее второго
}
else
    if (dec.size > size)
    {
        result.size = dec.size;
        k = 2; // если к == 2, значит второе число длиннее первого
    }
    else // если числа одинаковой длинны, то необходимо сравнить их веса
        for (unsigned ix = 0; ix < result.size;) // поразрядное сравнение весов чисел
        {
        if ((int)val[ix] > (int)dec.val[ix]) // если разряд первого числа больше
            {
                k = 1; // значит первое число длиннее второго
                break; // выход из цикла for
            }
 
        if((int)dec.val[ix] > (int)val[ix]) // если разряд второго числа больше
            {
                k = 2; // значит второе число длиннее первого
                break; // выход из цикла for
            }
        }
        if (k==1) {difference(val,dec.val,result.val, result.size,size,dec.size); result.sing=1; }
        if (k==2) {difference(dec.val,val,result.val, result.size,dec.size,size); result.sing=-1; }
   return result;
}
TDecimal TDecimal::operator*(const TDecimal& dec)
    {
    TDecimal result;
    result.size = dec.size + size + 1;
 
    for (unsigned ix = 0; ix < size; ix++)
       for (unsigned jx = 0; jx < dec.size; jx++)
           result.val[ix + jx] += val[ix] * dec.val[jx];
 
    for (unsigned ix = 0; ix < result.size; ix++)
    {
     result.val[ix + 1] +=  result.val[ix] / 10;
     result.val[ix] %= 10;
    }
while ((int)result.val[result.size] == 0)
    result.size-- ;
return result;
    }
//----------------------------------------------//
bool TDecimal::operator == (const TDecimal& dec)
{
   bool eq = (size == dec.size);
   if (eq)
   {
      for (unsigned i = 0; i < size; ++i)
      {
         if (size == dec.size)
         {
            eq = false;
            break;
         }
      }
   }
   return eq;
}
//----------------------------------------------//
bool TDecimal::operator < (const TDecimal& dec)
{
   bool less = (size < dec.size);
   if ((less == false) && (size == dec.size))
   {
      for (unsigned i = size-1; i < size; --i)
      {
         if (val[i] != dec.val[i])
         {
            less = (val[i] < dec.val[i]);
            break;
         }
      }
   }
   return less;
}
//----------------------------------------------//
bool TDecimal::operator > (const TDecimal& dec)
{
   bool larger = (size > dec.size);
   if ((larger == false) && (size == dec.size))
   {
      for (unsigned i = size-1; i < size; --i)
      {
         if (val[i] != dec.val[i])
         {
            larger = (val[i] > dec.val[i]);
            break;
         }
      }
   }
   return larger;
}
//----------------------------------------------//
ostream& operator << (ostream& os, const TDecimal& digit)
{
if (digit.sing==-1) os<<"-";
   for (unsigned i = digit.size-1; i < digit.size; --i)
   {
      os << (int) digit.val[i];
   }
   return os;
}
//----------------------------------------------//
int main()
{
   TDecimal a("12435435436234632");
   TDecimal b("242341523163464573");
   cout << "a = " << a << endl;
   cout << "b = " << b << endl;
   cout << "a+b = " << (a+b) << endl;
   cout << "a-b = " << (a-b) << endl;
   cout << "b-a = " << (b-a) << endl;
   cout << "b*a = " << b*a << endl;
   system ("PAUSE");
   return 0;
}
Помогите Реализовать класс Array, ещё плохо разбираюсь с наследованием и т.д
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 12:16. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru