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

классы - C++

Восстановить пароль Регистрация
 
kaffein
 Аватар для kaffein
5 / 5 / 1
Регистрация: 14.11.2010
Сообщений: 121
13.04.2011, 19:11     классы #1
Всем доброго времени суток ))

люди помогите с классами
вот задание :
1. реализировать конструктор по умолчанию, копирования и деструктор.
2.конструкторы которые принимают количество елементов и их начальное значение, а другой количество елементов и указатель на данные, что сохраняются.
3. реализировать оператор приведения до типа который сохраняет класс
4.методы: получение количества елементов класс; добавить елемент; выдалить элемент; поиск подстроки в строке.
5.Операторы :
вектор operator += (вектор)
вектор operator +=(<тип данних>)
вектор operator = (вектор)
вектор operator == (вектор)
вектор operator != (вектор)
<тип данних> operator [] (int i)
Дружні функції
вектор operator +(вектор, вектор)
вектор operator +(вектор, <тип данних>)
вектор operator +(<тип данних>, вектор)
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
#include "stdafx.h"
#include "stdio.h"
#include <time.h> 
#include <stdlib.h>
 
class vector
{  
private:
    int* m;
    int size;
public :
    vector(int n = 100);
    vector( vector &vector2);
   explicit vector(int *data, int size);
   explicit vector(int size,int val);
   ~vector();
  
   int GetSize();
   int Push(int val);
   void Pop();
   int Push_x(int x);
   int GetPos(int val);
   void print();
    vector operator = (vector& vector2);
    vector operator += (const vector& s);//+
    vector operator += (const int val);//+
    vector operator = (const vector& s);//+
    int operator == (const vector& s);//+
    int operator != (const vector& s);//+ 
    vector operator [] (int n);
 
 
};
vector::vector( int n  )
{   
    if (n < 0) n = 0;
    size = n;
    m = NULL;
    if(size)
if( (m = new int[size]) == NULL)
 size = 0;
}
vector::vector( vector& vector2)
{
    size = vector2.size;
    m = NULL;
    if(size)
       if( (m =new int[size]) == NULL)
          size = 0;
       else
    for(int i = 0; i<size;i++)
        *(m + i) = vector2.m[i];
    printf("kopia stvorena !");
}
vector::~vector()
{
        delete[] m;
}
vector::vector(int *data, int size)
{
    this->size = size;
    m = NULL;
    if(size)
       if( (m =new int[size]) == NULL)
          size = 0;
       else
    for(int i = 0; i<size;i++)
       *(m + i) = data[i];
}
vector::vector(int size,int val)
{
      this->size = size;
         m = NULL;
      if(size)
         if( (m =new int[size]) == NULL)
            size = 0;
         else
    for(int i = 0; i<size;i++)
            *(m + i) = val;
 
}
inline int vector::GetSize(){return size;}
inline int vector::Push(int val)
{
   *m = val;
   size ++ ;
   return val;
}
 
void vector::Pop()
{
    size = 0;
    delete[] m; 
}
 
int vector::Push_x(int x)
 {
   for(int i=0;i<size;i++)
      if(m[i]==x)
         {
           if(i==(size-1))
              {
                m[i]=NULL;
                size--;
                break;
              }
    for(int j=i;j<size-1;j++)
          {
             m[j]=m[j+1];
          }
             size--;
  }
 
 
         
    return *m ;
         
 }
int vector::GetPos(int val)
{
    for(int i = 0; i<size; i++)
        if(m[i] == val)
            return i;
}
void vector::print()
{
 printf("%d",m);
}
 
vector vector::operator += (const vector& vector2)
{
    if (size != vector2.size) 
        return *this;
    for (int i = 0; i < size; i++)
        *(this->m + i) += *(vector2.m + i);
    return *this;
}
 
vector vector::operator += (int value)
{
    int i;
    for (i = 0; i < size; i++)
        *(this->m + i) += value;
    return *this;
}
 
vector vector::operator = (vector& vector2)
{
if (this == &vector2) return *this;
size = vector2.size;
m = NULL;
if (size)
if ((m=new int[size]) == NULL)
size = 0;
else
for (int i = 0; i < size; i++)
*(m + i) = vector2.m[i];
return *this;
}
 
int vector::operator == (const vector& vector2)
{
if (size != vector2.size) return 0;
for (int i = 0; i < size; i++)
{
if (*(this->m + i) != *(vector2.m + i))
return 0;
}
return 1;
}
 
int vector::operator != (const vector& vector2)
{
if (size != vector2.size) return 1;
for (int i = 0; i < size; i++)
{
if (*(this->m + i) != *(vector2.m + i))
return 1;
}
return 0;
}
 
vector vector::operator [] (int n)
{
if (n < 0) n = 0;
 
if (n >= size) n = size - 1;
return *( this -> m + n );
}
void rand_vect( vector& x,int size)
{
    for (int i=0; i<size; i++)
    {
        x.Push(rand()%10+1);
    }
}
void print( vector& x,int size)
{
    for( int i=0; i<size; i++)
    {
       x.print();
    }
}
 
int main()
{  
     vector x(10);
     rand_vect(x,10);
     print(x,10);
     system("pause");
    return 0;
}
посмотрите правильно ли я всё реализировал и подскажите как написать метод: поиск подстроки в строке.
зарание спасибо
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.04.2011, 19:11     классы
Посмотрите здесь:

Классы C++
C++ КЛАССЫ
C++ Классы
классы C++
классы C++ C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
mansp
18 / 18 / 0
Регистрация: 07.11.2010
Сообщений: 136
13.04.2011, 21:35     классы #2
Хомяк це ти?)))
kaffein
 Аватар для kaffein
5 / 5 / 1
Регистрация: 14.11.2010
Сообщений: 121
13.04.2011, 22:34  [ТС]     классы #3
mansp, ты о чём ??? это что шутка ???
mansp
18 / 18 / 0
Регистрация: 07.11.2010
Сообщений: 136
13.04.2011, 23:10     классы #4
Код
void vector::Pop()
{
        size = 0;
        delete[] m; 
}
не правильно...
функция поп должа выталкивать последний елемент а не удалаять весь вектор...
и вопрос? как ты собрался искать подрядок в строке?? ведь у тебя не масив чаров...
может быть ты задание перепутал?
Yandex
Объявления
13.04.2011, 23:10     классы
Ответ Создать тему
Опции темы

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