Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
1

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

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

Author24 — интернет-сервис помощи студентам
Привет всем!Мне очень нужна ваща помощь в исправлении ошибок в классе.
Вот сам класс
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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
31.05.2011, 17:02
Ответы с готовыми решениями:

Подскажите что такое классы и как они работают
Значит, написал я программу, отправил учителю, а в ответ получил: 1. Программа по-прежнему не...

Объясните 35-36 строчки ,что они делают и для чего они ?
//--------------------------------------------------------------------------- #include&lt;iostream.h&gt;...

Для чего нужны сужающие преобразования как они работают и на сколько они важны?
Я читаю одну книгу и застрял на одной теме &quot;Преобразования&quot;, и там есть такой вот код double х...

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

17
594 / 532 / 76
Регистрация: 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
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
01.06.2011, 08:49  [ТС] 3
str это переменная типа класса.я ее там с помощью дивов и модов переводил в массив

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

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

Добавлено через 13 часов 25 минут
плз хоть кто-нибудь
0
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
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
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
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 17:54  [ТС] 6
я канечно незнаю но препод конструкторы смотрел сказал мол правильно.Хотя может он проглядел сейчас исправлю.

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

Добавлено через 17 минут
Деструктор вылез за объявление класса. Строки 63 и 64 поменять.
operator == в строке 167 должен возвращать bool.
Затем, в аргументах операторов == и + используется указатель. Это так надо? Мне кажется там нужна константная ссылка. Ну или не константная, хотя константная лучше.
1
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:16  [ТС] 8
в них динамические должны быть(препод настаивает говорит типа это хороший стиль програмирования) у + ==.А насчет деструктора я растяпа)).Щас исправлю.А там еще были какие то ошибки.Вот с операторами + и(насчет равно неуверен).
0
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
02.06.2011, 18:17 9
Кто динамический должен быть?
0
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:18  [ТС] 10
"в строке 167 должен возвращать bool".я чтот непонял я же написал стрцмп и ретурн в нем.Что же еще я должен возвратить?
0
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
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
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
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
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
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
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
02.06.2011, 18:34 15
Я не уверен, но подозреваю, что это как раз из-за указателя в аргументе вместо ссылки.
0
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:46  [ТС] 16
тогда он ругается на [C++ Error] Unit1.cpp(178): E2288 Pointer to structure required on left side of -> or ->*
0
Эксперт С++
2381 / 1665 / 279
Регистрация: 29.05.2011
Сообщений: 3,399
02.06.2011, 18:47 17
Ну да, разумеется, вместо xxx->str надо будет использовать xxx.str
1
3 / 3 / 1
Регистрация: 02.03.2010
Сообщений: 75
02.06.2011, 18:57  [ТС] 18
ок все понятн.щас пойду исправлять свой алгоритм.спс

Добавлено через 3 минуты
Вот блин ток спрашивается вопрос зачем нас 1.5 года на паскале мучили после него в с++ перейти сложновато(по крайней мере для меня).

Добавлено через 3 минуты
а вот как перевести из строки по символьно в массив?
0
02.06.2011, 18:57
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
02.06.2011, 18:57
Помогаю со студенческими работами здесь

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

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

Как struct Queue и его операции превратить в классы, то есть нужно сделать тоже самое, но через классы
Как struct Queue и его операции превратить в классы, то есть нужно сделать тоже самое, но используя...

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


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

Или воспользуйтесь поиском по форуму:
18
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru