Реализация операций с присваиванием и соответствующих бинарных операций сложности не представляет1, поэтому покажем в качестве примера реализацию трех операций умножения (листинг 5.15). Остальные операции реализуются точно так же — надо только заменить знак операции сложения.
Листинг 5.15. Реализация операций сложения
ТАггау& ТАггау::operator+=(const double &rhs) { for(Uint i = 0; i<size_array; ++i)
datafi] *= rhs; // складываем с текущим объектом
return *this;
}
TArray& ТАггау::operator+=(const ТАггау &rhs)
{ if (size_array == rhs. si ze__array) // защита
{ for(Uint i = 0; i<size_array; ++i)
data[i] *= rhs.data[i]; // изменяем текущий объект
}
return *this;
}
ТАггау operator+(const ТАггау &a, const TArray &b)
{ TArray temp = a; // левый аргумент
if (a.sizeO == b.sizeO) // защита
temp += b; // добавляем - наша операция
return temp;
}
При умножении массивов необходимо проверять равенство размеров. Если количество элементов не совпадает, то возвращается левый аргумент операции. Во втором методе это — текущий объект. В последнем случае создается локальный объект, которому и присваивается левый массив. Если размеры левого и правого массивов совпадают, то правый массив добавляется к локальному массиву. В противном случае он остается без изменения и возвращается в качестве результата.
В дополнение к этим функциям можно реализовать еще два варианта дружественных функций сложения массива с числом:
friend ТАггау operator+(const ТАггау &а. const double &b); friend TArray operator+(const double &a, const TArray &b);
Два варианта необходимо, чтобы не было проблем с коммутативностью.
Для примера покажем еще реализацию операций, вычисляющих различные произведения элементов массивов (листинг 5.16). Аналогично реализуются и методы суммирования.
Во втором методе product () используется реализация первого метода, причем сначала, как обычно, создается локальный объект.
Последняя функция вычисляет скалярное произведение двух массивов. Если размеры массивов не совпадают, то умножения не происходит и возвращается сумма элементов левого аргумента.
Во время программирования можно http://tvspectr.ru/radio-online.html тут.
Мы пока не обращаем внимания на эффективность реализации.
Листинг 5.16. Методы и функции произведений
double ТАггау::product() { double р = 1.0;
for(Uint i = 0; i<size_array; ++i)
p*=data[i]; // работаем с текущим массивом
return р;
}
double ТАггау::product(Uint begin, Uint end)
{ TArray temp(*this, begin, end); // создаем локальный массив из текущего
return temp.product(); // работает предыдущий метод
}
double product__dot(const TArray &a, const TArray &b)
{ TArray temp (a); // локальный объект из левого аргумента
if (a.sizeO == b.sizeQ) // защита
temp *= b; // поэлементное умножение
return temp.summa(); // вычисление суммы локального массива
}
Для реализации метода сортировки используем стандартный алгоритм sort(), входящий в состав стандартной библиотеки, — посмотрите, как просто это делается (листинг 5.17). |