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

Перегрузка операций - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Составить блок-схемы программ http://www.cyberforum.ru/cpp-beginners/thread983976.html
Помогите составить блок-схемы программ. Заранее спасибо. Всем peace. #include "stdafx.h" int _tmain(int argc, _TCHAR* argv) { return 0; }
C++ Считывание и запись в файл Visual Studio Здравствуйте. Встала задача считать из файла 3 числа через пробел, и вывести их в другой файл.. Перерыл много страниц, но точного кода не нашел, заранее спасибо. http://www.cyberforum.ru/cpp-beginners/thread983964.html
Не работает прорамма с классами C++
Не могу понять где ошыбка и как ее исправить . Друзья, помогите пожалуйста 1>------ Построение начато: проект: ConsoleApplication2, Конфигурация: Debug Win32 ------ 1> flower.cpp 1>c:\users\оксана\documents\visual studio 2012\projects\consoleapplication2\consoleapplication2\flower.h(28): error C2059: синтаксическая ошибка: { 1>c:\users\оксана\documents\visual studio...
C++ Формула в С++,подскажите как записать
Всем привет,помогите пожалуйста записать формулу в С++.Буду очень благодарен.
C++ Классы в С++ http://www.cyberforum.ru/cpp-beginners/thread983918.html
Ребята, помогите пожалуйста. Я новичок в программировании, а сессия заканчивается. Нужно привести пример класса (С++): описание класса, пример его использования, показать наследование. инкапсуляцию. В классе обязательно должен быть конструктор и деструктор. Очень надеюсь на помощь.
C++ Генерация лабиринта Разработать приложение, генерирующее лабиринт размером m x n клеток. Дополнительные условия: а) Вход и выход – произвольные клетки лабиринта; б) Только один путь от входа к выходу; в) При перегенерации лабиринта, каждый последующий лабиринт должен отличаться от предыдущего; г) Вывести путь от входа к выходу.... подробнее

Показать сообщение отдельно
Only_Loko
 Аватар для Only_Loko
10 / 10 / 0
Регистрация: 20.09.2013
Сообщений: 22
21.10.2013, 22:27     Перегрузка операций
Здравствуйте! Ниже приведено задание, которое я практически сделал(перегружаемые операции приведены не все). Вопрос в том, что я не понял где мне использовать int index_l и int index_h. Да, и как перегрузить операцию индексирования,я тоже не очень понял. Помогите, пожалуйста.

Составить описание класса для представления одномерных массивов
вещественных чисел (векторов):
typedef double T;
class TVector{
private:
T *v; // одномерный массив
int size; // количество элементов
int index_l; // нижний индекс
int index_h; // верхний индекс
public:

};
При создании объектов
класса TVector предусмотреть возможность задания произвольных границ
индексов, определяемые полями index_l и index_h.
Список перегружаемых операций и методов:
· + – операция сложения векторов;
· - – операция вычитания векторов;
· * – операция скалярного умножения векторов;
· операции извлечь из потока >> и поместить в поток <<;
· = – операция присваивания;
· [ ] – операция индексирования, т.е. обращение к отдельному элементу
массива с контролем выхода за границы, определяемые index_l и index_h;
· конструктор по умолчанию;
· конструктор с параметрами;
· конструктор копирования;
-----------------------------------------------------------------------------------------------------------------------
Вот сам код программы:
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
#include<iostream>
#include<cmath>
#include<Windows.h>
#include<process.h>
 
using namespace std;
 
typedef double T;
class TVector{
private:
    T *v;
    int size;
    int index_l;
    int index_h;
public:
    TVector(); //конструктор по умолчанию
    TVector(int n);      //конструктор с параметрами
    TVector(const TVector &ob);    //конструктор копий
    ~TVector();
    TVector operator + (const TVector&); 
        TVector operator = (const TVector&); 
        TVector operator - (const TVector&); 
        T operator * (const TVector&);  
        TVector operator -() const;               // унарный минус 
    friend  ostream& operator << (ostream&, TVector&); 
        friend  istream& operator >> (istream&, TVector&); 
};
 
TVector::TVector() // реализация конструктора по умолчанию
{ 
      size = 0;
      v = new T[size]; 
} 
 
TVector::TVector(int n) // реализация конструктора с параметрами
{  
    size= n;
    v = new T[size];  
    for ( int i = 0; i <size; ++i) 
          v[i]= 0;
 
} 
 
TVector::TVector(const TVector &ob) // реализация конструктора копии
{   
    size = ob.size; 
    v = new T[size];   
    for ( int i = 0; i <size; ++i) 
         v[i]= ob.v[i];
 
}  
 
TVector::~TVector() // деструктор
{  
    delete[] v;
}
 
 
TVector TVector::operator=(const TVector& ob) // оператор присваивания
{ 
    if(this->size!=ob.size)
    {
        cout<<"Ошибка! Разный размер векторов!"<<endl;
        exit(1);
        
    }
    else{
    int i;                      
    for ( i = 0; i < this->size; ++i) 
            this->v[i] = ob.v[i]; 
    return *this;
    }
} 
 
 
TVector TVector :: operator + ( const TVector& ob) // сумма векторов
{  
    if(this->size!=ob.size)
    {
        cout<<"Ошибка! Разный размер векторов!"<<endl;
        exit(1);
    }
    else{
    TVector temp;                       
    int i;
    temp.size = this->size;
    temp.v = new T[temp.size]; 
    for ( i = 0; i < temp.size; ++i) 
         temp.v[i] = this->v[i] + ob.v[i]; 
    return temp;
    }
} 
TVector TVector :: operator - (const TVector& ob)
{
    if(this->size!=ob.size)
    {
        cout<<"Ошибка! Разный размер векторов!"<<endl;;
        exit(1);
    }
    else{
    TVector temp;                       
    int i;
    temp.size = this->size;
    temp.v = new T[temp.size]; 
    for ( i = 0; i < temp.size; ++i) 
         temp.v[i] = this->v[i] - ob.v[i]; 
    return temp;
    }
}
 
T TVector::operator *(const TVector& ob)
{
    if(this->size!=ob.size)
    {
        cout<<"Ошибка! Разный размер векторов!"<<endl;;
        exit(1);
    }
    else{
    T pr = 0.0;
    for(int i=0; i<this->size; i++)
    {
        pr=pr+v[i]*ob.v[i];
    }
    return pr;
    }
}
 
istream& operator >> (istream& input, TVector& ob)
{
    for(int i=0; i<ob.size; i++)
        input>>ob.v[i];
 
    return input;
}
 ostream& operator << (ostream& out, TVector& ob)
 {
     cout<<endl;
     for(int i=0; i<ob.size; i++)
         out<<ob.v[i]<<" ";
     return out;
 }
 
int main()
{
    int n1, n2;
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    cout<<"Введите размер 1-го вектора\n";
    cin>>n1;
    cout<<"Введите размерность 2-го вектора\n";
    cin>>n2;
    TVector obj(n1), obj2(n2), obj3(n1);
    cout<<"Введите элементы 1-го вектора: \n";
    cin>>obj;
    cout<<"Введите элементы 2-го вектора: \n";
    cin>>obj2;
    obj3=obj+obj2;
    cout<<"Сумма векторов: "<<obj3<<endl;
    obj3=obj-obj2;
    cout<<"Разность векторов: "<<obj3<<endl;
    T pr=obj*obj2;
    cout<<"Скалярное произведение векторов: \n"<<pr<<endl;
    obj=obj2;
    cout<<"Присвавивание 2-го вектора 1-му: "<<obj<<endl;
    return 0;
}
Заранее спасибо!)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 22:28. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru