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

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

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

Дроби - C++

26.09.2011, 21:08. Просмотров 394. Ответов 0
Метки нет (Все метки)

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
#include <iostream>
#include <conio.h>
using namespace std;
 
class rational
{
public:
    int a,b,c,d,oper,res1,res2;
void init(void);
void read(void);
void proc(void);
void display(void);
int nod (int x, int y);
void reduce (void);
};
 
 
//ввод//
 
void rational::read(void)
{
    int x,y;
    cout<<"vvedit 1 drob"<<endl;
    cin>>x;
    cout<<"/";
    cin>>y;
    if(y!=0)
    {
        a=x;b=y;
    }
    else cout<<"error,znamennuk ne mae dorivnuvatu 0"<<endl;
 
    cout<<endl;
 
    cout<<"vvedit 2 drob"<<endl;
    cin>>x;
    cout<<"/";
    cin>>y;
        if(y!=0)
    {
        c=x;d=y;
    }
    else cout<<"error,znamennuk ne mae dorivnuvatu 0"<<endl;
    cout<<endl;
}
 
//инициализация//
void rational::init(void)
{
    int z;
cout<<"initialization"<<endl;
cout<<"bajaete vvestu drobu(1)?"<<endl<<"4u otrumatu ix vupadkovum 4unom(2)?"<<endl;
cin>>z;
 
switch(z)
    {
    case 1: read();break;
    case 2: cout<<"vupadkovi drobu"<<endl;
        a=rand() % 10 + 1;
        b=rand() % 10 + 1;
        c=rand() % 10 + 1;
        d=rand() % 10 + 1;
        cout<<a<<"/"<<b<<endl;
        cout<<c<<"/"<<d<<endl;
        break;
 
    default: cout<<"error"<<endl;
        init();
 
    }
}
 
//вычисление//
void rational::proc(void)
{
    cout<<"oberit bajany operaciy"<<endl;
    cout<<"1-add\n2-sub\n3-mul\n4-div\n5-equal,greate,less"<<endl;
    cin>>oper;
 
    switch(oper)
    {
    case 1: cout<<"Suma:"<<endl; res1=a*d+b*c; res2=b*d; display(); break;
    case 2: cout<<"riznucia:"<<endl; res1=a*d-b*c; res2=b*d; display(); break;
    case 3: cout<<"dobutok:"<<endl; res1=a*c; res2=b*d; display();  break;
    case 4: cout<<"4astka:"<<endl; res1=a*d; res2=b*c; display();   break;
    case 5: cout<<"porivnannia drobiv:"<<endl; 
        if(a*d>b*c) cout<<a<<"/"<<b<<"  >   "<<c<<"/"<<d<<endl;
        else if(a*d<b*c) cout<<a<<"/"<<b<<" <   "<<c<<"/"<<d<<endl;
        else        cout<<a<<"/"<<b<<"  =   "<<c<<"/"<<d<<endl;
        break;
 
    default: cout<<"nemae takoi operacii"<<endl;
 
    }
}
 
//поиск найбольшего кратного//
int rational::nod (int x, int y)
{
    while (x!=y)
    {
      
        if(x>y)
            
            if(x%y!=0)
                x=x%y;
            else x=y;
        else if (x<y)
            if (y%x!=0)
                {
                y=y%x;
                x=y;
                }
    }
    return x;
}
 
//сокращение//
void rational::reduce()
 
{
    int n;
    cout<<"ckoro4ennia droba:"<<endl;
    if(res1==0)
        return;
    if (res1<0)  n=nod(-res1,res2);
    else         n=nod(res1,res2);
    res1=res1/n;
    res2=res2/n;
 
}
 
//вывод//
void rational::display(void)
{
    cout<<res1<<"/"<<res2<<endl;
 
        if (res1==res2) cout<<"Vidpovidb=1";
        else if(res1==0) cout<<"Vidpovidb=0";
        else 
        {
            reduce();
            cout<<res1<<"/"<<res2<<endl;
        }
}
 
void main()
{
rational obj;
obj.init();
obj.proc();
 
getch();
}
программа работает с двумя дробями, числитель и знаменатель которых в отдельных переменных.
все работает но кусок, который ищет найбольшее общее кратное, работает направильно, и из-за этого дроби неправильно сокращаются. Есть ли у кого идеи как сделать даную функцию?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
int rational::nod (int x, int y)
{
    while (x!=y)
    {
      
        if(x>y)
            
            if(x%y!=0)
                x=x%y;
            else x=y;
        else if (x<y)
            if (y%x!=0)
                {
                y=y%x;
                x=y;
                }
    }
    return x;
}
Добавлено через 54 секунды
закройте плиз тему, нечаянно продублировал)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.09.2011, 21:08     Дроби
Посмотрите здесь:

Дроби - C++
Помогите решить тут

Дроби - C++
Вот простенькая прога, делаю лабу.. работает с двумя дробями у которых числитель и знаменатель в отдельных переменных. #include...

Дроби - C++
можете объяснить что делает каждая функция #include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;stdlib.h&gt; #include &quot;fraction.h&quot; ...

Дроби - C++
Borland C ++ Даны натуральные числа X и Y, являющиеся числителем и знаменателем дроби соответственно. Вывести на экран все общие делители...

Структура дроби - C++
Есть структура, которая описывает смешанную дробь. Надо найти сумму дробей через функцию.

Дроби!классы - C++
что исправить чтобы скомпилировалось?// дроби.cpp: определяет точку входа для консольного приложения. // #include &quot;stdafx.h&quot; ...

Обыкновенные дроби - C++
Как осуществить вывод чисел в виде обыкновенных дробей в С++?

Оператор For и дроби - C++
Написать при помощи оператора For..... которая считает величину (см. прикрепленный файл) { int n,K; float S,a; ...

Сокращение дроби - C++
Даны натуральные числа a и b, обозначающие соответственно числитель и знаменатель дроби. Сократите дробь, т.е найти такие натуральные p и...

Обыкновенные дроби - C++
Составить программу выполняющая арифметические операции над обыкновенными дробями,результат должен быть несократимой дробью


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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