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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
#1

Опять они ... классы - C++

31.05.2011, 17:02. Просмотров 797. Ответов 17
Метки нет (Все метки)

Привет всем!Мне очень нужна ваща помощь в исправлении ошибок в классе.
Вот сам класс
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
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <string.h>
class _string
  { protected:
  char *str;
  int len;
  public:
  _string()
  {
   str=new char;    //constructor without parametrs
   str[0]='\0';
   len=0;
  }
 
  _string(char *st)
  {int i=0;
   while (st[i]!='\0')   //constructor with C string
   i++;
   len=i;
   str=new char[i];
   strcpy(str,st);
   }
 
  _string(char st)         //construcnor for symbol
  {   str=new char;
      str[0]=st;
      str[1]='\0';
      len=1;
   }
 
  _string(_string &str1)  //copy constructor
 {   str=new char;
     len=str1.len;
     strcpy(str,str1.str);
 }
 void show ()
 {
  cout<<str<<"   "<<len<<endl;
 }
 int dlina(char *st)
 {
 int i;
 while (st[i]!='\0')
 i++;
 len=i;
 return len;
  }
 char *clear(char *st)   //function clear
    {
    st[0]='\0';
     strcpy(str,st);
     return str;
     }
 };
 //~_string() { delete str; len=0;}  //destructor
 
 
 
  class bit_string: public _string    //child
  {
  public:
  bit_string()
  {                //constructor  without parametrs
  _string();
  }
 
  bit_string(char *st):_string(st)
  {
 
     int i=0;
 
     while (str[i]!='\0')
        {if ((str[i]!='0') && (st[i]!='1')&& (st[i]!='-')) {
                                             str[0]='\0';
                                             len=0;
                                             break;
                                            }
                                            i++;
         }
   }
 
   bit_string(char st):_string(st)         //construcnor for symbol
   {
   //_string(st)
   if  ((str[0]!='0') && (str[0]!='1')) {str[0]='\0';
                                len=0; }
   }
   bit_string(bit_string &str1):_string(str1)  //copy constructor
 {   str=new char;
     len=str1.len;
     strcpy(str,str1.str);
 }
  
  // ~string() { delete str; }; 
 
    char *negative_number ()
     { int *mas;
        mas=new int [10];                              //convert to negative number
        int i,l,dl,smart;
      if (str[0]=='-') {i=1;
                      while (str[i]!='\0') {
                                         if (str[i]=='0') str[i]='1';
                                         if (str[i]=='1') str[i]='0';
                                         i++;
                                         l+=i;
                                         }
                        i=0;
                        int a,b,c,s;
                        c=atoi(str);
                        while (b>0)
                        {
                        a=c % 10;
                        b=c / 10;
                        c=b;
                        mas[l]=a;
                        l=l-1;
                        }
                        smart=0;
                        s=0;
                        for (i=l;i>0;i--)
                        {
                        s=mas[i]+1;
                        if (s=1) {mas[i]=1; smart=0;}
                        if (s=2) {mas[i]=0; smart=1;}
                        if (s=3) {mas[i]=1; smart=1;}
                        if (smart==0) break;
                        }
                       }
        while (l>i)
     {itoa( mas[i],str,10);
     return str;
     };
 
 bit_string operator == (bit_string *str1)
   {
    if (strcmp(str,str1->str))
      return false;
     };
 bit_string operator = (bit_string *str1)
 {
 };
 bit_string operator + (bit_string *str1)
 { int mas1,mas2,a1,a2,b1,b2,s,sn=0,l1,l2,i,j,l;
   int *m1,*m2,*m;
   m1=new int [10];
   m2=new int [10];
   m=new int [10];
   mas1=atoi (str1->str);
   mas2=atoi (str);
    l1=strlen(str1->str);
    l2=strlen(str);
   l=l1+l2;
   sn=0;
   for (i=l;l-1<i;i++)
   {
   a1=mas1 % 10;       // mod
   a2=mas2 % 10;
   b1=mas1 / 10;       // div
   b2=mas2 / 10;
   mas1=b1;
   mas2=b2;
   m1[l1]=a1;
   m2[l2]=a2;
   l1--;
   l2--;
   }
   for (i=l;i>0;i--)
   {
   s=m2[l2]+m1[l1]+sn;
   if (s==0) {m[i]=0; sn=0;}
   if (s==1) {m[i]=1; sn=0;}
   if (s==2) {m[i]=0; sn=1;}
   if (s==3) {m[i]=1; sn=1;}
   l1--;
   l2--;
   }                   i=0;
   while (l>i)
     {itoa( m[i],str,10);
                                   i++;}
     return str;
 }
 };
 
int main(int argc, char* argv[])
{
 bit_string s1;
 s1.show();
 bit_string s2("-0101");
 s2.negative_number();
 s2.show();
 bit_string s3(s2);
 s3.show();
 bit_string s4('k');
 s4.show();
 getch();
 
 return 0;
Собсно ошибка вроде в процедуре negative_cod(перевод в дополнительный код)
и в других местах кому несложно пожалуйста помогите исправить недачоты.
Срывается автомат из него.Буду очень признателен.
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.05.2011, 17:02
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Опять они ... классы (C++):

Два мальчика купили билеты в кино. До начала сеанса они решили поиграть в щелбаны. Они называют по одной цифр - C++
Два мальчика купили билеты в кино. До начала сеанса они решили поиграть в щелбаны. Они называют по одной цифре билета. У кого цифра...

Непонятна тема (Классы содержащие другие классы, как данные члены ) - C++
Изучаю книгу Джесс Либерти(в частности эту главу в данный момент) #include &lt;iostream&gt; class Point { public: void SetX(int...

Программа по классам, которая использует классы точек и прямых на плоскости, а, возможно, и другие классы - C++
Нужно написать программу, которая использует классы точек и прямых на плоскости, а, возможно, и другие классы. Реализовать её нужно в трех...

Наследование, базовые классы и производные классы - C++
Добрый вечер.Задание: необходимо разработать поля и методы наследуемые из базового класса и собственные компоненты производных...

Классы и наследование (Создать класс 3D фигура, и производные классы шар, конус, цилиндр и куб. Создать функцию вычисления объёма.) - C++
Уважаевые, помогите написать прожку на экзамене: Создать класс 3D фигура, и производные классы шар, конус, цилиндр и куб. Создать функцию...

Классы возможностей(Mixin классы) - C++
Не могу понять смысла использования mixin классов( это класс в котором есть только методы и нет членов-данных) Т.е. к примеру у нас...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
OstapBender
583 / 521 / 35
Регистрация: 22.03.2011
Сообщений: 1,585
31.05.2011, 17:47 #2
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
    char *negative_number ()
     { int *mas;
        mas=new int [10];                              //convert to negative number
        int i,l,dl,smart;
      if (str[0]=='-') {i=1;
                      while (str[i]!='\0') {
                                         if (str[i]=='0') str[i]='1';
                                         if (str[i]=='1') str[i]='0';
                                         i++;
                                         l+=i;
                                         }
                        i=0;
                        int a,b,c,s;
                        c=atoi(str);
                        while (b>0)
                        {
                        a=c % 10;
                        b=c / 10;
                        c=b;
                        mas[l]=a;
                        l=l-1;
                        }
                        smart=0;
                        s=0;
                        for (i=l;i>0;i--)
                        {
                        s=mas[i]+1;
                        if (s=1) {mas[i]=1; smart=0;}
                        if (s=2) {mas[i]=0; smart=1;}
                        if (s=3) {mas[i]=1; smart=1;}
                        if (smart==0) break;
                        }
                       }
        while (l>i)
     {itoa( mas[i],str,10);
     return str;
     };
что это???

в сроке str содержится число и нужно его перевести в доп-код?

Добавлено через 14 минут
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
    char str[32+1]="10010100";
 
    puts(str);
 
    int val;
    char *p;
 
    val=strtol(str,&p,2);
 
    val=-val;
 
    itoa(val,str,2);
 
    puts(str);
возможно так
1
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
01.06.2011, 08:49  [ТС] #3
str это переменная типа класса.я ее там с помощью дивов и модов переводил в массив

Добавлено через 2 минуты
и еще что еще за пут я просто новичок в с++ если есть возможность то поясняйте что пишите.И еще если возникнут вопросы по коду то я поясню что и как я там делал

Добавлено через 2 минуты
люди хелп!!!

Добавлено через 13 часов 25 минут
плз хоть кто-нибудь
0
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 17:30  [ТС] #4
Вот вроде я тут пофиксил но помощь еще нужна.Плз кто нибудь посматрите у меня тут ошибка(и) в синтаксисе я незнаю что исправить чтоб заработало.вот переделаный код
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
241
242
243
244
245
246
247
//---------------------------------------------------------------------------
 
#pragma hdrstop
 
//---------------------------------------------------------------------------
 
#pragma argsused
#include <iostream.h>
#include <conio.h>
#include <string.h>
class _string
  { protected:
  char *str;
  int len;
  public:
  _string()
  {
   str=new char;    //constructor without parametrs
   str[0]='\0';
   len=0;
  }
 
  _string(char *st)
  {int i=0;
   while (st[i]!='\0')   //constructor with C string
   i++;
   len=i;
   str=new char[i];
   strcpy(str,st);
   }
 
  _string(char st)         //construcnor for symbol
  {   str=new char;
      str[0]=st;
      str[1]='\0';
      len=1;
   }
 
  _string(_string &str1)  //copy constructor
 {   str=new char;
     len=str1.len;
     strcpy(str,str1.str);
 }
 void show ()
 {
  cout<<str<<"   "<<len<<endl;
 }
 int dlina(char *st)
 {
 int i;
 while (st[i]!='\0')
 i++;
 len=i;
 return len;
  }
 char *clear(char *st)   //function clear
    {
    st[0]='\0';
     strcpy(str,st);
     return str;
     }
 };
~_string() { delete str; len=0;}  //destructor
 
 
 
  class bit_string: public _string    //child
  {
  public:
  bit_string()
  {                //constructor  without parametrs
  _string();
  }
 
  bit_string(char *st):_string(st)
  {
 
     int i=0;
 
     while (str[i]!='\0')
        {if ((str[i]!='0') && (st[i]!='1')&& (st[i]!='-')) {
                                             str[0]='\0';
                                             len=0;
                                             break;
                                            }
                                            i++;
         }
   }
 
   bit_string(char st):_string(st)         //construcnor for symbol
   {
   if  ((str[0]!='0') && (str[0]!='1')) {str[0]='\0';
                                len=0; }
   }
   bit_string(bit_string &str1):_string(str1)  //copy constructor
 {   str=new char;
     len=str1.len;
     strcpy(str,str1.str);
 }
  
~ bit_string() { } //destractor
 
    char *negative_number ()
     { int *m;
         m=new int [10];                              //convert to negative number
        int i,l,dl,smart,k=0;
      if (str[0]=='-') {i=1;  l=0; str[0]='0';
                      while (str[i]!='\0') {
                                         if (str[i]=='0') {str[i]='1';}
                                         else  {str[i]='0';}
                                         i++;
                                         l=i;
                                         }
                        int a,b,c,s;
                        c=atoi(str);
                        l--;
                        while (b!=0)
                        {
                        a=c % 10;    //mod
                        b=c / 10;    //div
                        c=b;
                        m[l]=a;
                        l--;
                        }
                        smart=1;
                        s=0;
                        l=i-1;
                        for (i=l;i>0;i--)
                        {
                        s=m[i]+1;
                        if (s==1)
                          {m[i]=1;
                           smart=0;}
                        if (s==2)
                           {m[i]=0;
                            smart=1;}
                        if (s==3)
                           {m[i]=1;
                            smart=1;}
                        if (smart==0) break;
                        }
                       }
        for (i=0;i<l;i++)
        {
        if (m[i]!=1)
        k++;
        else break;  
        }
        int c,a;
        c=0;
 
        while (l>=k)
        {
        c+=m[k];
        if (l==k) break;
        c*=10;
        k++;
        }
     itoa(c,str,10);
     i++;
 
     return str;
 
     };
 
 bit_string operator == (bit_string *str1)
   {
    if (strcmp(str,str1->str))
      return false;
     };
 
 
 bit_string operator + (bit_string *str1)
 { int mas1,mas2,a1,a2,b1,b2,s,sn=0,l1,l2,i,j,l,k;
   int m1[5],m2[5],m[5];
   mas1=atoi (str1->str);
   mas2=atoi (str);
    l1=strlen(str1->str);
    l2=strlen(str);
   l=l1+l2;
   sn=0;
   for (i=l;0<i;i++)
   {
   a1=mas1 % 10;       // mod
   a2=mas2 % 10;
   b1=mas1 / 10;       // div
   b2=mas2 / 10;
   mas1=b1;
   mas2=b2;
   m1[l1]=a1;
   m2[l2]=a2;
   l1--;
   l2--;
   }
   for (i=l;i>0;i--)
   {
   s=m2[l2]+m1[l1]+sn;
   if (s==0) {m[i]=0; sn=0;}
   if (s==1) {m[i]=1; sn=0;}
   if (s==2) {m[i]=0; sn=1;}
   if (s==3) {m[i]=1; sn=1;}
   l1--;
   l2--;
   }
    for (i=0;i<l;i++)
        {
        if (m[i]!=1)
        k++;
        else break;  
        }
        int c,a;
        c=0;
 
        while (l>=k)
        {
        c+=m[k];
        if (l==k) break;
        c*=10;
        k++;
        }
     itoa(c,str,10);
     i++;
     return str;
 }
 };
 
int main(int argc, char* argv[])
{
 bit_string s1;
 s1.show();
 bit_string s2("-01010010");
 s2.negative_number();
 s2.show();
 bit_string s3(s2);
 s3.show();
 bit_string s4('k');
 s4.show();
 bit_string s5("100");
 bit_string s6;
 bit_string s7("100");
 s6=s5+s7;
 s6.show();
 getch();
 
 return 0;
}
//-------------------------------------------------------------------------
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 17:44 #5
Посмотрел конструкторы только. Практически везде память выделяется неверно.
В первом конструкторе выделяется память под переменную, а надо под массив из 1 элемента, т.е.
C++
1
str=new char[1];
Во втором не выделяется память для хранения завершающего нуля, а функция strcpy этот ноль записывает, портя чужую память. Надо
C++
1
str=new char[i+1];
В третьем и четвёртом снова та же ошибка, что и в первом. Нужно создать массивы с размерами 2 и str1.len+1 соответственно.

Добавлено через 1 минуту
И в деструкторе, соответственно, надо удалять массив:
C++
1
~_string() { delete [] str; len=0;}  //destructor
1
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 17:54  [ТС] #6
я канечно незнаю но препод конструкторы смотрел сказал мол правильно.Хотя может он проглядел сейчас исправлю.

Добавлено через 4 минуты
тем боле я вызывал их и она работали.Кста-ти посматри уж ошиббки остальные.Очень буду признателен.
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 18:11 #7
Ну первый-то, в принципе, нормально работать будет, а три других память портят однозначно.

Добавлено через 17 минут
Деструктор вылез за объявление класса. Строки 63 и 64 поменять.
operator == в строке 167 должен возвращать bool.
Затем, в аргументах операторов == и + используется указатель. Это так надо? Мне кажется там нужна константная ссылка. Ну или не константная, хотя константная лучше.
1
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:16  [ТС] #8
в них динамические должны быть(препод настаивает говорит типа это хороший стиль програмирования) у + ==.А насчет деструктора я растяпа)).Щас исправлю.А там еще были какие то ошибки.Вот с операторами + и(насчет равно неуверен).
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 18:17 #9
Кто динамический должен быть?
0
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:18  [ТС] #10
"в строке 167 должен возвращать bool".я чтот непонял я же написал стрцмп и ретурн в нем.Что же еще я должен возвратить?
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 18:22 #11
вот заголовок:
Цитата Сообщение от gorgutz1234 Посмотреть сообщение
C++
1
bit_string operator == (bit_string *str1)
первое слово говорит, что возвращать будем bit_string, а возвращаем bool
должно быть
C++
1
bool operator == (bit_string *str1)
Добавлено через 2 минуты
Кстати, а что если строки равны? Тогда вообще ничего не возвращается? А должно возвращаться true
0
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:23  [ТС] #12
вот исправил ты это имел ввиду?
C++
1
2
3
4
5
bit_string operator == (bit_string *str1)
     {
    if (strcmp(str,str1->str))==0 {return true;}
      return false;
     };
хотя он ругается что я неправильно написал стрцмп.
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 18:26 #13
Вот так:
C++
1
2
3
4
5
6
bool operator == (bit_string *str1)
{
    if (strcmp(str,str1->str) == 0)
        return true;
    return false;
};
1
gorgutz1234
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:30  [ТС] #14
там вот еще ошибка
[C++ Error] Unit1.cpp(243): E2093 'operator+' not implemented in type 'bit_string' for arguments of the same type

Добавлено через 33 секунды
эт когда я делал проверку своего оператора +
0
grizlik78
Эксперт С++
1911 / 1443 / 112
Регистрация: 29.05.2011
Сообщений: 3,000
02.06.2011, 18:34 #15
Я не уверен, но подозреваю, что это как раз из-за указателя в аргументе вместо ссылки.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.06.2011, 18:34
Привет! Вот еще темы с ответами:

Классы, включающие другие классы - C++
Столкнулся вот с таким кодом: #include &lt;iostream&gt; class Point { public: void SetX(int x) {itsX = x;} void SetY(int y) ...

классы/дочерние классы/методы - C++
помогите пожалуйста! надо что выводились только учебеники. чтоб былo через GetTip. h файл class Book { protected: char...

Опять файлы - C++
Если, я открыл файл записал туда данные, а потом пытаюсь читать эти данные до тех пор пока не встретится конец файл. Это будет корректно?...

Опять ошибка - C++
Идет ошибка сегментации, а я в программировании не так силен, понять не могу в чем проблема... (+ Выдает ошибки, когда количество...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
02.06.2011, 18:34
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru