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

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

Войти
Регистрация
Восстановить пароль
 
vedenkov
0 / 0 / 0
Регистрация: 29.10.2011
Сообщений: 6
#1

Помогите с оператором в комплексном калькуляторе на c++ builder 6 - C++

29.10.2011, 07:44. Просмотров 761. Ответов 3
Метки нет (Все метки)

написал комплексный калькулятор, все работает кроме одного: когда вводиш 1.2-1.1 то выдает 0.9999999999999 а не 0.1...подскажите что делать
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.10.2011, 07:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Помогите с оператором в комплексном калькуляторе на c++ builder 6 (C++):

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

помогите с оператором условия - C++
вычислить номер дня в невисокосном году по заданным числу и месяцу на данный момент имею вот это: void main() { double...

ПОМОГИТЕ РЕШИТЬ В builder for dos - C++
Написать программу,которая считывает текст с клавиатуры и выводит его на экран, меняя местами каждые два соседних слова.

помогите пожалуйста изменить прогу написанную в C++builder, под C++VisualStudio - C++
программа для архивирования графич. файлов писалась на билдере, но у меня он криво работает. Помогите пожалуйста,подскажите где надо...

Как описать в C++Builder 6 в калькуляторе кнопку +/-? - C++ Builder
Как описать в C++Builder 6 в калькуляторе кнопку +/-? Спасибо! Минус ставлю, когда надо стиреть, то стирается вместе с цифрой... ...

Как описать в C++Builder 6 в калькуляторе кнопку Вкл/Вык? - C++ Builder
Как описать в C++Builder 6 в калькуляторе кнопку Вкл/Вык? Спасибо!

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
greeezz
272 / 165 / 4
Регистрация: 10.07.2011
Сообщений: 441
29.10.2011, 07:47 #2
если вы покажите ваш код, то станет проще разбираться.
vedenkov
0 / 0 / 0
Регистрация: 29.10.2011
Сообщений: 6
29.10.2011, 07:50  [ТС] #3
Complex.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
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
#ifndef MATH_H
#include <math.h>
#else
#define MATH_H
#endif
 
#ifndef IOS_H
#include <iostream.h>
#else
#define IOS_H
#endif
 
#include <vcl\dstring.h>
 
const double pi = 3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679;
bool COMPLEX_FORMAT=false;
 
class complex{
private:
double x,y;
 
public:
complex(double re=0,double im=0){x=re; y=im;}
 
//--------------------------------------------------------------------
 
friend complex exp(complex);
friend complex pow(complex,complex);
friend complex sqrt(complex);
friend complex log(complex);
friend complex sinh(complex);
friend complex cosh(complex);
friend complex sin(complex);
friend complex cos(complex);
friend complex tan(complex);
 
friend void    print(complex);
friend complex input(void);
 
friend double  real(complex z) {return z.x;}
friend double  image(complex z){return z.y;}
friend double  mod(complex z)  {return sqrt(z.x*z.x+z.y*z.y);}
friend double  arg(complex z)  {return (z.x||z.y)?atan2(z.y,z.x):0;}
 
friend complex       StrToCompl(AnsiString);
friend AnsiString    ComplToStr(complex);
 
friend complex operator~(complex);
friend complex operator+(complex,complex);
friend complex operator-(complex,complex);
friend complex operator-(complex);
friend complex operator*(complex,complex);
friend complex operator/(complex,complex);
friend complex operator^(complex,complex);
friend bool    operator==(complex,complex);
friend bool    operator!=(complex,complex);
};
 
//----------------------------------------------------------------------------
 
complex operator~(complex z)
{return complex(z.x,-z.y);}
 
complex operator+(complex z1,complex z2)
{return complex(z1.x+z2.x,z1.y+z2.y);}
 
complex operator-(complex z1,complex z2)
{return complex(z1.x-z2.x,z1.y-z2.y);}
 
complex operator-(complex z)
{return complex(-z.x,-z.y);}
 
complex operator*(complex z1,complex z2)
{return complex(z1.x*z2.x-z1.y*z2.y,z1.x*z2.y+z2.x*z1.y);}
 
complex operator/(complex z1,complex z2)
{return complex((z1.x*z2.x+z1.y*z2.y)/(z2.x*z2.x+z2.y*z2.y),
                (z1.y*z2.x-z2.y*z1.x)/(z2.x*z2.x+z2.y*z2.y));}
 
complex operator^(complex z1,complex z2)
{return exp((log(mod(z1))+complex(0,1)*arg(z1))*z2);}
 
bool operator==(complex z1,complex z2)
{return z1.x==z2.x&&z1.y==z1.y;}
 
bool operator!=(complex z1,complex z2)
{return z1.x!=z2.x||z1.y!=z1.y;}
 
//---------------------------------------------------------------------
double  mod(double x){return fabs(x);}
double  mod(int x){return abs(x);}
 
complex exp(complex z)
{return complex(exp(z.x)*cos(z.y),exp(z.x)*sin(z.y));}
 
complex pow(complex z1,complex z2)
{return exp((log(mod(z1))+complex(0,1)*arg(z1))*z2);}
 
complex sqrt(complex z)
{return pow(z,0.5);}
 
complex log(complex z)
{return complex(log(mod(z)),arg(z));}
 
complex cosh(complex z)
{return (exp(z)+exp(-z))/2;}
 
complex sinh(complex z)
{return (exp(z)-exp(-z))/2;}
 
complex cos(complex z)
{ complex i=complex(0,1); return cosh(i*z);}
 
complex sin(complex z)
{ complex i=complex(0,1); return -i*sinh(i*z);}
 
complex tan(complex z) {return(sin(z)/cos(z));
}
complex input(void){
char s[80],sx[40],sy[40],*ps;
double xs,ys;
cin>>s;
*sx=0;*sy=0;
ps=s;   if(*ps=='(')                strcpy(s,++ps);
ps=s;   while(*ps) ps++; ps--;      if(*ps==')')*ps=0;
ps=s;   while(*ps!=','&&*ps) ps++;
        if(*ps==','){*ps=0; ps++; strcpy(sy,ps);}
strcpy(sx,s); xs=atof(sx);
*sy ? ys=atof(sy): ys=0;  complex z=complex(xs,ys);
return z;
}
 
void print(complex z) { z.y ? cout <<"("<<z.x<<","<<z.y<<")" : cout<<z.x;}
 
//ПРЕОБРАЗОВАНИЕ СТРОКИ ТИПА AnsiString В КОМПЛЕКСНОЕ ЧИСЛО
 
complex StrToCompl(AnsiString s){
char *cs,*ps,*es;
char sx[40],sy[40];
const char lp='(',rp=')';
double xs,ys;
cs=s.c_str();
        if(!strcmp(cs,"INF"))  return complex(1e308,0);
        if(!strcmp(cs,"-INF")) return complex(-1e308,0);
*sx=0;*sy=0; ps=cs; while(*ps)ps++; ps--; es=ps; ps=cs;
if(*ps==lp&&*es!=rp||*ps!=lp&&*es==rp) return complex(0,0);
else if(*ps==lp&&*es==rp) {*es=0; ps++; strcpy(cs,ps);}
 
ps=cs;
while(*ps) ps++; ps--; es=ps;
if(*ps=='i'){
        if(ps==cs)return complex(0,1);
        *ps=0;ps--;
        while(*ps!='+'&&*ps!='-'&&ps!=cs)ps--;
        if(ps==cs){strcpy(sy,cs); strcpy(sx,"0");}
        else if(*ps=='+'||*ps=='-'){
             strcpy(sy,ps); *ps=0; strcpy(sx,cs);
        }
        if(!strcmp(sy,"+")||!strcmp(sy,"-")) strcat(sy,"1");
        xs=atof(sx); ys=atof(sy);
   }
else{
        ps=cs;   while(*ps!=';'&&*ps!=','&&*ps) ps++;
        if(*ps==';'||*ps==','){*ps=0; ps++; strcpy(sy,ps);}
        strcpy(sx,cs); xs=atof(sx); ys=*sy ? atof(sy):0;
}
complex z=complex(xs,ys); return z;
}
 
//ПРЕОБРАЗОВАНИЕ КОМПЛЕКСНОГО ЧИСЛА В СТРОКУ ТИПА AnsiString
 
AnsiString ComplToStr(complex z){
AnsiString *s =  new AnsiString[80];
AnsiString *rs = new AnsiString[40];
AnsiString *is = new AnsiString[40];
double re,im; const AnsiString lp='(',rp=')',c=';',ci='i';
 
re=real(z);                     im=image(z);
if(fabs(re)<1e-308) re=0;        if(fabs(im)<1e-308) im=0;
 
*rs=FloatToStr(re);      *is=FloatToStr(im);
if(COMPLEX_FORMAT) {
        if(!re&&!im)            *s="0";
        if(re)                  *s=*rs;
        if(im==1&&re)           *s+="+i";
        else if(im==1)          *s="i";
        else if(im>0&&re)       *s+=("+"+*is+"i");
        else if(im>0)           *s+=(*is+"i");
        if(im==-1)      *s+="-i";
        else if(im<0)   *s+=(*is+"i");
}
else {
        if(im) *s=lp+*rs; else  *s = *rs;
        if(im) *s += (c+*is+rp);
}
delete[] is;  delete[] rs;
return *s;
}
//----------------------------------------------------------------------------
оператор сложения в само программе:
C++
1
2
3
4
5
void __fastcall TForm1::ToolButtonAddClick(TObject *Sender)
{
Result=StrToCompl(Edit1->Text)+StrToCompl(Edit2->Text);
PanelResult->Caption=ComplToStr(Result);   PanelOp->Caption="Z1+Z2=";
}
 Комментарий модератора 
Используйте теги форматирования кода!
greeezz
272 / 165 / 4
Регистрация: 10.07.2011
Сообщений: 441
29.10.2011, 07:58 #4

Не по теме:

мдя.. тут без стакангенса не разберешься


поковыряю насколько сил хватит разобраться. может кто поопытнее подключится.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.10.2011, 07:58
Привет! Вот еще темы с ответами:

Как сделать чтобы в калькуляторе результат выводился и на мемо?c++ builder, help me - C++ Builder
хочу чтобы калькулятор при написании цифр выводился результат на мемо, чтобы при нажатии кнопки C(стереть), стиралась толко поля в Edit, a...

Помогите пожалуйста с условным оператором в запросе - MS Access
Доброго всем времени суток! Сложилась проблемка с запросом. Необходимо формирование в запросе поля &quot;площадка&quot; в зависимости от значения...

.NET 4.x Возможно ли воспользоваться в VB.NET оператором логического сдвига Shr (Shl) и оператором And? - Visual Basic .NET
Возможно ли воспользоваться в VB.NET оператором логического сдвига Shr (Shl) и оператором And?

Фильтр в комплексном компоненте каталог - 1С Битрикс
Народ помогите плз) Использую комплексный компонент &quot;Каталог&quot;, включаю в нем &quot;умный фильтр&quot; и он почему то криво работает... списки...


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

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

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