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

Не получается перевести 2 массива в строку - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Шаблоны или ... (Maximum option context replay depth exceeded) http://www.cyberforum.ru/cpp-beginners/thread608123.html
Код отсюдВа http://habrahabr.ru/post/38622/ //------------------------------------------------------------ template <unsigned long t> struct Polynome { static const unsigned long value = t&1 ?...
C++ CodeBlocks ошибка Всем салют! Недавно купил книгу с++ для чайников и у меня проблемы с самым первым заданием. Набрал я этот код: // // Conversion - Program to convert temperature from // Celsius... http://www.cyberforum.ru/cpp-beginners/thread608121.html
C++ Глобальные static переменные
main.h class Test { public: void test(); }; static int x; test.cpp
Массив. Работа со строчками и столбцами. Деление на выбрвнную строчку C++
Доброго времени суток всем!!Помогите ,п-та!Я в тупике. #include <iostream> using namespace std; int main () { int n, k, st,sv ; int i = 0, j = 0; double **mas;
C++ Расчет количество дней прожитых со дня рождения http://www.cyberforum.ru/cpp-beginners/thread608077.html
Сабж. Может есть у кого исходный код который рассчитывает количество прожитых дней со дня рождения(сегодняшний день и день рождения офк подаются как входные данные)? желательно с помощью ООП
C++ С + + и Visual C + + и чем они отличаются? Есть ли их изучение взаимно дополняющее или это совсем разные языки? Просветите убогого =) подробнее

Показать сообщение отдельно
vitek_v
0 / 0 / 0
Регистрация: 18.06.2012
Сообщений: 6

Не получается перевести 2 массива в строку - C++

18.06.2012, 01:50. Просмотров 366. Ответов 2
Метки (Все метки)

Здравствуйте всем.
Вобщем, курсовая, заданее следущее:
написать класс для чисел единый, чтобы можно было складывать разные типы,
int с double, длинные числа и т.п
я додумался записывать числа в строки, потом складывать отдельно дробную часть, отдельно целую (в массивах), после записывать в строку, но когда пытаюсь слить в строку сложенную дробную и целую часть ничего не выходит, не пойму в чем ошибка...
в программе пока только сложение дробного с дробным, также еще нужно разность, умножение, деление...
Помогите пожалуйста понять в чем ошибка или посоветуйте другой способ решение задачи вообще,
я думаю, что это далеко не самое лучшее.
P.S. извиняюсь если, что не так, первый раз пользуюсь форумом, да и сроки сдачи курсовой подходят к концу...
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
#include <iostream.h>
#include <string.h>
#include <time.h>
#include <stdlib.h>
using namespace std;
class SpecialType
{
    public:
       char x[100];
       SpecialType()
       {
           this->x;
       }
 
    string GetNumber()  // вернуть число
     {
         return this->x;
     }
    /* ФУНКЦИИ РАБОТЫ СО СТРОКАМИ И МАССИВАМИ */
    int Length(char *number) // длина числа (РАБОТАЕТ)
     {
         int i=0;
         while (number[i])
            {
                i++;
            }
         return i;
     }
    bool  Point(char *number) // если точка в числе (РАБОТАЕТ)
     {
         for (int i=0;i<Length(number);i++)
           if (number[i] == '.')
             {
                 return true;
             }
 
         return false;
     }
    void Zanulim(int *a,int len)
     {
         for (int i=0;i<len;i++)
           a[i]=0;
     }
    int LenBeforePoint(char *number)
     {
         int size=0;
         for (int i=0;i<Length(number);i++)
            {
                if (number[i]=='.') break;
                else if(number[i]=='\0') break;
                else size++;
            }
 
         return size;
     }
    int LenAfterPoint(char *number)
     {
         int size=0,i=0;
         for (i=0;number[i]!='.';i++);// считаем сколько нужно элементов в массиве
         for (int k=i+1;number[k]!='\0';k++)
           {
               size++;
           }
         return size;
     }
    void BeforePoint(char *number,int *a)  // перевести в массив из строки число до точки, т.е. целую часть
     {
         int i = 0;
         while (number[i]!='.')
           {
             i++;
           }
         for (int k=i;k>=0;k--)
           {
               a[k] = number [k] - '0';
           }
     }
 
    void AfterPoint(char *number,int *a) // перевести в массив из строки число до точки, т.е. дробную часть
     {
         int i = 0;
         while (number[i]!='.')
           {
             i++;
           }
         for (int j = i+1;j<Length(number);j++)
           {
               a[j-i-1] = number [j] - '0';
           }
 
     }
    void InChar(int *a,int len1,int *b,int len2,char *Chislo) // ПЕРЕВОД МАССИВА В СТРОКУ
     {
        // char *Chislo = new char[len1 + len2 + 2];
         int k = 0;
         while (a[k] == 0)
           {
               k++;
           }
         Chislo[0] = '\0';
        int i;
         for (i = 0;i<len1;i++)
           {
               Chislo[i] = '0' + a[i]; //Объединим строку buffer и Chislo
           }
         Chislo[i+1] = '.';
         for (int j = i + 2;j < (len2 + len1 + 1);j++)
           {
               Chislo[j] = '0' + b[j]; //Объединим строку buffer и Chislo
           }
 
     }
 
    /* ОПЕРАЦИИ */
 
    SpecialType Addition(SpecialType A) // сложение
     {
         if (Point(this->x) && Point(A.x))
           {
               /* СЛОЖЕНИЕ ДРОБНОЙ ЧАСТИ */
               SpecialType Sum;
               int MaxLenD;
               if (LenAfterPoint(this->x)>LenAfterPoint(A.x))  MaxLenD = LenAfterPoint(this->x);
               else MaxLenD = LenAfterPoint(A.x);
               int *c=new int[MaxLenD]; // создаем дим. массив
                 Zanulim(c,MaxLenD);
                 AfterPoint(this->x,c);
               int *d=new int[MaxLenD];
                 Zanulim(d,MaxLenD);
                 AfterPoint(A.x,d);
               int *SumD=new int[MaxLenD+1];
               Zanulim(SumD,MaxLenD+1);
               int ostD = 0; // для остатка если сумма цифр больше 10ти
               int one = 0; // если при сумма дробной части больше 1
               for (int j=MaxLenD-1;j>=0;j--)
                  {
                      SumD[j+1] = (c[j] + d[j] + ostD) % 10;
                      ostD = (c[j] + d[j] + ostD) / 10;
                  }
                one = SumD[0];
               /* СЛОЖЕНИЕ ЦЕЛОЙ ЧАСТИ */
               int MaxLenC;
               if (LenBeforePoint(this->x)>LenBeforePoint(A.x))  MaxLenC = LenBeforePoint(this->x);
               else MaxLenC = LenBeforePoint(A.x);
               int *a=new int[MaxLenC]; // создаем дим. массив
                Zanulim(a,MaxLenC);
                BeforePoint(this->x,a);
               int *b=new int[MaxLenC]; // создаем дим. массив
                Zanulim(b,MaxLenC);
                BeforePoint(A.x,b);
               int *SumC=new int[MaxLenC+1];
                Zanulim(SumC,MaxLenC+1);
               int ostC = 0; // для остатка если сумма цифр больше 10ти
               SumC[MaxLenC] = (a[MaxLenC - 1] + b[MaxLenC - 1] + one) % 10;
               ostC = (a[MaxLenC - 1] + b[MaxLenC - 1] + one) / 10;
               for (int j=MaxLenC-2;j>=0;j--)
                  {
                      SumC[j+1] = (a[j] + b[j] + ostC) % 10;
                      ostC = (a[j] + b[j] + ostC) / 10;
                  }
                InChar(SumC,MaxLenC,SumD,MaxLenD,Sum.x);
                return Sum;
 
 
           }
         else if (Point(this->x) && Point(A.x)==false)
           {
 
           }
         else if  (Point(this->x)==false && Point(A.x))
           {
 
           }
         else
           {
 
           }
 
     }
 
};
int main()
{
  SpecialType A,B,C;
  cin >> A.x >> B.x;
  C = A.Addition(B);
  cout << C.GetNumber();
  return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru