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

Решение всех упражнений из книги Р. Лафоре "Объектно-ориентированное программирование в С++" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Конвертер текстового файла http://www.cyberforum.ru/cpp-beginners/thread439174.html
Добрый день!!! Простите за наглость... Помогите пожалуйста написать программу-конвертер текстовых файлов из dos в windows и обратно. С командной строки должно вводится направление /d или /w. Я очень мало в этом понимаю. Заранее спасибо!!!
C++ Проблема с libmms - ошибка при компиляции. Здравствуйте. Уже который день не могу разобраться с упомянутой в заголовке библиотекой, а именно: пишу примерно такой тестовый код #include <iostream> #include <libmms/mms.h> int main() { mms_t *stream; char mms_link="mms://audio.rfn.ru/radiorus/audio/710/90.asf"; stream=mms_connect(0, 0, mms_link, 128); http://www.cyberforum.ru/cpp-beginners/thread439169.html
C++ Привет. Как можна найти с даного примера умножение элементов массива с четными номерами?
#include "stdafx.h" #include <stdlib.h> #include <stdio.h> #include <conio.h> #include <iostream> using namespace std; int main(int argc, _TCHAR* argv)
C++ Начало DEV С++
Здравствуйте, подскажите где ошибка? Задание Даны действительные числа х, у . Если х, у отрицательные то каждое значение заменить его модулем; если отрицательное только одно из них, то оба значения увеличить на 0.5; если оба значения не отрицательные и ни одно из них не принадлежат отрезку , то оба значения уменьшить в 10 раз; в остальных случаях х, у оставить без изменения. Решение ...
C++ Запись текста в файл http://www.cyberforum.ru/cpp-beginners/thread439138.html
Нужно составить прогрумма которая создает файл и записывает в него текст. Программа не записывает в файл текст после пробела, помогите пожалуйста. char name; char text; cout<<"vvedite put' i im9 faila:\n"; cin>>name; ofstream out(name); cout<<"vvedite text:\n"; cin>>text; out<<text; out.close();
C++ allocator std::map Подскажите вопрос, есть тестовое задание: Написать allocator для std::map, располагающий элементы контейнера последовательно в памяти. Подскажите где про это почитать и разъясните по-возможности, что это вообще такое (std::map я вкурсе что это контейнер и как с ним работать) в ступор вводит allocator подробнее

Показать сообщение отдельно
kickupduster
 Аватар для kickupduster
4 / 4 / 1
Регистрация: 04.08.2013
Сообщений: 20
02.09.2013, 17:38     Решение всех упражнений из книги Р. Лафоре "Объектно-ориентированное программирование в С++"
Цитата Сообщение от MacInsider Посмотреть сообщение
Я хотел спросить у всех, есть ли у кого то решение 1 задания (проекта) из главы 13
Если интересно, то вот мой вариант решения Глава 13. Задание 1
verylong.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
// verylong.h
// описатель класса сверхбольших целых чисел
#include <iostream>
#include <string.h>            //для strlen()и т. п.
#include <stdlib.h>            //для ltoa()
using namespace std;
 
const int SZ = 1000;           //максимальное число разрядов
 
class verylong
  {
  private:
      bool minus;
      char vlstr[SZ];            //число как строка
      int vlen;                  //длина строки verylong
      verylong multdigit(const int) const; //прототипы
      verylong mult10(const verylong) const;// скрытых функций
  public:
    verylong() : vlen(0)       //конструктор без аргументов
      { vlstr[0]='0'; vlstr[1]='\0'; minus = false;}
    verylong(const char s[SZ]) //конструктор (1 аргумент)
      {                        //для строки
          strcpy(vlstr, s); 
          vlen=strlen(s);
          minus = false;
      } 
    verylong(const unsigned long n) //конструктор (1 арг.)
      {                             //для long int
      ltoa(n, vlstr, 10);           //перевести в строку
      strrev(vlstr);                //перевернуть ее
      vlen=strlen(vlstr);           //найти длину
      minus = false;
      } 
    void putvl() const;              //вывести число
    void getvl();       //получить число от пользователя
    verylong operator + (const verylong); //сложить числа
    verylong operator * (const verylong); //умножить
    verylong operator - (const verylong);
    verylong operator / (const verylong);
    verylong operator ++ (int);
    bool operator == (const verylong) const;
    bool operator < (const verylong) const;
    bool operator > (const verylong) const;
    bool operator >= (const verylong) const;
    bool operator <= (const verylong) const;
    bool operator != (const verylong) const;
    friend verylong abs(const verylong&);
  };
verylong.cpp
Кликните здесь для просмотра всего текста
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
// verylong.cpp
// реализация обработки данных типа verylong
#include "verylong.h"        //заголовочный файл для verylong
//---------------------------------------------------------
void verylong::putvl() const //вывод на экран verylong
  {
  char temp[SZ];
  strcpy(temp,vlstr);        //создать копию
  if (minus == true)
  {
      temp[vlen] = '-';
      temp[vlen+1] = '\0';
  }
  cout << strrev(temp) << endl;      //перевернуть копию
  }                          //и вывести ее
//---------------------------------------------------------
void verylong::getvl()       //получить сверхбольшое число от
                             //пользователя
  {
    cin >> vlstr;              //получить строку от пользователя
    vlen = strlen(vlstr);      //найти ее длину
    strrev(vlstr);             //перевернуть ее
    if (vlstr[vlen-1] == '-') 
    {
        vlstr[vlen-1] = '\0';
        minus = true;
        vlen -= 1;
    }
  }
//---------------------------------------------------------
verylong verylong::operator + (const verylong v)
                             //сложение
  {
      if (minus == true && v.minus == false) return abs(v) - abs(*this);
      if (minus == false && v.minus == true) return abs(*this) - abs(v);
  char temp[SZ];
  int j;
  int maxlen = (vlen > v.vlen) ? vlen : v.vlen; //найти самое длинное число
  int carry = 0;             //установить в 1, если сумма >= 10
  for(j = 0; j<maxlen; j++)  //и так для каждой позиции
    {
    int d1 = (j > vlen-1)  ? 0 : vlstr[j]-'0';    //получить
                                                  //разряд
    int d2 = (j > v.vlen-1) ? 0 : v.vlstr[j]-'0'; //и еще
    int digitsum = d1 + d2 + carry;  //сложить разряды
    if( digitsum >= 10 )             //если перенос, то
      { digitsum -= 10; carry=1; }   //увеличить сумму на 10
    else                     //установить перенос в 1
      carry = 0;             //иначе перенос = 0
    temp[j] = digitsum+'0';  //вставить символ в строку
    }
  if(carry==1)               //если перенос в конце,
    temp[j++] = '1';         //последняя цифра = 1
  temp[j] = '\0';            //поставить ограничитель строки
  if (minus == true && v.minus == true) 
  {
      verylong t(temp); 
      t.minus = true; 
      return t;
  }
  return verylong(temp);     //вернуть временный verylong
  }
//---------------------------------------------------------
verylong verylong::operator - (const verylong v)
{
    if (minus == true && v.minus == false) return *this = *this + v;
    if (minus == false && v.minus == true) return abs(*this) + abs(v);
    char temp[SZ];
    int j;
    int maxlen = (vlen > v.vlen) ? vlen : v.vlen;  //найти самое длинное число
  int carry = 0;             //установить в 1, если сумма >= 10
  for(j = 0; j<maxlen; j++)  //и так для каждой позиции
    {
    int d1 = (j > vlen-1)  ? 0 : vlstr[j]-'0';    //получить
                                                  //разряд
    int d2 = (j > v.vlen-1) ? 0 : v.vlstr[j]-'0'; //и еще
    int digitsum; //сложить разряды
    (*this < v)? digitsum = d2 - d1 - carry : digitsum = d1 - d2 - carry;  
    if( digitsum < 0 )               //если перенос, то
      { digitsum += 10; carry=1; }   //увеличить сумму на 10
    else                     //установить перенос в 1
      carry = 0;             //иначе перенос = 0
    temp[j] = digitsum+'0';  //вставить символ в строку
    }
  temp[j] = '\0';  
  for(int i=j-1; i>0; i--)
  {
      if (temp[i] == '0') temp[i] = '\0';
      else break;
  }
  if (*this < v) 
  {
       verylong t(temp);
       t.minus = true;
       return t;
  }
  return verylong(temp);     //вернуть временный verylong
}
//---------------------------------------------------------
verylong verylong::operator * (const verylong v)//умножение
  {                                             //сверхбольших чисел
  verylong pprod;            //произведение одного разряда
  verylong tempsum;          //текущая сумма
  for(int j=0; j<v.vlen; j++)//для каждого разряда аргумента
    {
    int digit = v.vlstr[j]-'0'; //получить разряд
    pprod = multdigit(digit);   //умножить текущий на него
    for(int k=0; k<j; k++)      //умножить результат на
      pprod = mult10(pprod);    //  степень 10-ти
    tempsum = tempsum + pprod;  //прибавить произведение к
                                //текущей сумме
    }
  if (minus == true || v.minus == true) tempsum.minus = true;
  if (minus == true && v.minus == true) tempsum.minus = false;
  return tempsum;               //вернуть полученную текущую сумму
  }
//---------------------------------------------------------
bool verylong::operator == (const verylong v) const
{return (vlen == v.vlen && strcmp(vlstr,v.vlstr) == 0 && ((minus == true && v.minus == true) || (minus == false && v.minus == false)))? true: false;}
//---------------------------------------------------------
bool verylong::operator < (const verylong v) const
{
 
    if (((vlen < v.vlen) && (minus == false && v.minus == false)) || (minus == true && v.minus == false)) return true;
    if ((vlen > v.vlen) && (minus == true && v.minus == true)) return true;
    if (vlen == v.vlen)
    {
        if (minus == false && v.minus == true) return false;
        char *str1 = new char[vlen], *str2 = new char[v.vlen];
        strcpy(str1,vlstr); strcpy(str2,v.vlstr);
        strrev(str1); strrev(str2);
        if (strcmp(str1, str2) > 0 && (minus == true && v.minus == true)) return true;
        if (strcmp(str1, str2) < 0 && (minus != true && v.minus != true)) return true;
    }
    return false;
}
//---------------------------------------------------------
bool verylong::operator > (const verylong v) const
{
    verylong t(vlstr);
    t.minus = minus;
    return (!(t < v) && !(t == v))? true: false;
}
//---------------------------------------------------------
bool verylong::operator <= (const verylong v) const
{
    verylong t(vlstr);
    t.minus = minus;
    return (t < v || t == v)? true: false;
}
//---------------------------------------------------------
bool verylong::operator >= (const verylong v) const
{
    verylong t(vlstr);
    t.minus = minus;
    return (t > v || t == v)? true: false;
}
//---------------------------------------------------------
bool verylong::operator != (const verylong v) const
{
    verylong t(vlstr);
    t.minus = minus;
    return (!(t == v))? true: false;
}
//---------------------------------------------------------
verylong verylong::operator ++ (int)
{return *this = *this + 1;}
//---------------------------------------------------------
verylong abs(const verylong &v)
{
    verylong t;
    t = v;
    t.minus = false;
    return t;
}
//---------------------------------------------------------
verylong verylong::operator / (const verylong v) //целочисленное деление
{
    char *str_v = new char[vlen]; //временная строка
    strcpy(str_v,vlstr); strrev(str_v); //переворачиваем ее в нормальный вид
    verylong b, rez, vltemp, null;
    null.vlen = 1; 
    b = abs(v); //значение по модулю
    if (b == null) {cerr << "ОШИБКА!!! Деление на ноль!!!" << endl; return null;}
    if (abs(*this) < b) return null; //если делимое меньше делителя - возвращаем ноль
    for(int i=0, n=0; i<vlen;) //перебираем разряды делимого
    {
        while(vltemp < b) //берем разряды делимого
        {                 //пока не получим число большее делителя
            if (i >= vlen) return rez; 
            int d = str_v[i]-'0'; //берем разряд
            if (d == 0 && vltemp == null) rez = mult10(rez); //сносим нули при необходимости
            else vltemp = mult10(vltemp) + d; //формируем число 
            i++;
        }
        if (vltemp >= b) //если получили такое число
        {
            while(vltemp >= b) //уменшаем его
            {                  //пока остаток не станет меньше делителя
                vltemp = vltemp - b; 
                n++; //считаем значение разряда
            }
            rez = mult10(rez) + n; //формируем результат
            n = 0; //зануляем значение разряда
        }          //и повторяем цикл пока не пройдем весь велитель
    }
    if (minus == true || v.minus == true) rez.minus = true; //учитываем знаки исходных данных
    if (minus == true && v.minus == true) rez.minus = false;
    return rez;
}
//---------------------------------------------------------
verylong verylong::mult10(const verylong v) const //умножение аргумента 
                                                  //на 10
  {                
  char temp[SZ];
  for(int j=v.vlen-1; j>=0; j--)//сдвинуться на один разряд
    temp[j+1] = v.vlstr[j];     //выше
  temp[0] = '0';                //обнулить самый младший разряд
  temp[v.vlen+1] = '\0';        //поставить ограничитель строки
  return verylong(temp);        //вернуть результат
  }
//---------------------------------------------------------
verylong verylong::multdigit(const int d2) const
  {                          //умножение числа на
  char temp[SZ];             //аргумент (цифру)
  int j, carry = 0;
  for(j = 0; j<vlen; j++)    //для каждого разряда
    {              //  в этом сверхбольшом
    int d1 = vlstr[j]-'0';   //получить значение разряда
    int digitprod = d1 * d2; //умножить на цифру
    digitprod += carry;      //добавить старый перенос
    if( digitprod >= 10 )    //если возник новый перенос,
      {
      carry = digitprod/10;  //переносу присвоить //значение старшего разряда
      digitprod -= carry*10; //результату - младшего
      }
    else
      carry = 0;             //иначе перенос = 0
    temp[j] = digitprod+'0'; //вставить символ в строку
    }
  if(carry != 0)             //если на конце перенос,
    temp[j++] = carry+'0';   //это последний разряд
  temp[j] = '\0';            //поставить ограничитель
  return verylong(temp);     //вернуть сверхбольшое число
  }
main.cpp
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include "verylong.h"    //заголовочный файл verylong
int main()
  {
      setlocale(0,"rus");
      verylong *a, *b, *r; //объекты класса
      while(true){
      a = new verylong; b = new verylong; r = new verylong;
      cout << "Введите число: "; a->getvl(); //ввод данных
      cout << "Введите число: "; b->getvl();
      *r = *a + *b;
      cout << "Результат: "; r->putvl();
      *r = *a - *b;
      cout << "Результат: "; r->putvl();
      *r = *a * *b;
      cout << "Результат: "; r->putvl();
      *r = *a / *b;
      cout << "Результат: "; r->putvl();
      delete a,b,r;} //вывод на экран
  system("pause");
  return 0;
  }
 
Текущее время: 07:59. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru