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

классы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Экзамен по C http://www.cyberforum.ru/cpp-beginners/thread275864.html
Доброго времени суток. Мой друг учится на программиста. Но временно у него нет доступа к сети Интернет и он попросил меня помочь ему с решение задач ( я сам в программировании 0), и поэтому решил...
C++ Подскажите что не так? Нужно заменить цифры в числе на ноль, если цифра равна "a". А затем вывести получившееся число. число N - натуральное, а - является цифрой (от 0 до 9). например N = 12223 a = 2 должно получится... http://www.cyberforum.ru/cpp-beginners/thread275793.html
Указатели C++
int k=5; int *ukaz; ukaz=&k; *ukaz=17; printf("%o\n",ukaz); printf("%o\n",k); system("pause"); Может, что то я делаю не правильно, но по идее k дожен быть равен k=17, а результат выходит...
C++ Рисование линий по координатам
Здравствуйте! Возникла необходимость нарисовать линию по координатам. Есть ли в С++ ф-я, подобная ф-ии line в Pascal? line (x, y, x2, y2);
C++ Сортировка по алфавиту http://www.cyberforum.ru/cpp-beginners/thread275728.html
Ознакамливаюсь со структурами. Все прекрасно, осталось только отсортировать символьные массивы по алфавиту. Вот мой текст, в комментариях есть все задания.Программа вроде прокомментирована в...
C++ Как узнать координаты курсора мыши и отобразить их? c++ Как узнать координаты курсора мыши и отобразить их? c++ подробнее

Показать сообщение отдельно
kaffein
5 / 5 / 1
Регистрация: 14.11.2010
Сообщений: 121

классы - C++

13.04.2011, 19:11. Просмотров 361. Ответов 3
Метки (Все метки)

Всем доброго времени суток ))

люди помогите с классами
вот задание :
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;
}
посмотрите правильно ли я всё реализировал и подскажите как написать метод: поиск подстроки в строке.
зарание спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru