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

Сложение дробей. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вывести на экран шестнадцатеричное представление натурального числа http://www.cyberforum.ru/cpp-beginners/thread292771.html
Всем доброго времени суток. Задание: Вывести на экран шестнадцатеричное представление данного натурального числа. Сама рекурсия не вызывает проблем. Я считаю остаток о деления на 16 и целую часть. Когда целое деление невозможно рекурсия прекращается и тут возникает вопрос, как мне вытащить значения остатков от деления из стека? ведь у меня по сути есть только последнее значение. МАссивом...
C++ перечисляемый тип планеты=(меркурий,венера,земля,марс,юпитер,сатурн,уран,нептун,плутон); определить:пленету,ближайщую к солнцу;планету следующую зва ближайщей к солнцу;порядковый номер планеты земля от солнца;соседей планеты земля;прекдпоследнюю и последнюю планету от солнца. http://www.cyberforum.ru/cpp-beginners/thread292759.html
C++ Разработать алгоритм численного решения СЛАУ методом верхней релаксации
Помогите пожалуйста курсач горит (:ireful: Разработать алгоритм численного решения cистема линейных алгебраических уравнений методом верхней релаксации кто чем сможет помогите ..............
Структуры. Сделал C++
Сделал сам задачку, работает правильно, но нужно было через структуры, а я не понял как. #include <iostream> #include <fstream> #include <string> using namespace std; int main() { ifstream fin("input.txt"); ofstream fout("output.txt");
C++ Найти максимально возможную площадь сарая и где он может размещаться. http://www.cyberforum.ru/cpp-beginners/thread292719.html
Фермер хочет построить на своей земле как можно больший по площади сарай. Но на его участке есть деревья и хоз. постройки, которые он не хочет никуда переносить. Для простоты представим форму сеткой размера MxN. Каждое из деревьев и построек размещается в одном или нескольких узлах сетки. Прямоугольный сарай не должен ни с чем соприкасаться (т.е. в соседних с ним узлах сетки не может ничего...
C++ В массиве А из целых чисел..... В массиве А из чисел найти номер первого нечетного элемента.А чётные элементы этого массива заменить их индексами. подробнее

Показать сообщение отдельно
silent_1991
Эксперт C++
4945 / 3021 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
10.05.2011, 23:27     Сложение дробей.
Лучше создать структуру "Дробь", и хранить массив экземпляров этой структуры. Тогда можо спокойно написать функцию сложения двух дробей-экземпляров, и просто накапливать в первой переменной все суммы. Сейчас накидаю, как это может выглядеть...

Добавлено через 27 минут
Нечто подобное...

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
#include <stdio.h>
 
#define N 5
 
typedef struct Fraction
{
    int num;
    int den;
} Fraction;
 
Fraction construct_fraction(int, int);
int gcd(int, int);
void normalize_fraction(Fraction *);
Fraction frac_sum(Fraction, Fraction);
 
int main(void)
{
    Fraction frac_arr[N];
    Fraction sum = construct_fraction(0, 1);
    int temp_num, temp_den;
    int i;
 
    for (i = 0; i < N; ++i)
    {
        printf("Enter fraction %d: ", i + 1);
        scanf("%d %d", &temp_num, &temp_den);
 
        frac_arr[i] = construct_fraction(temp_num, temp_den);
    }
 
    for (i = 0; i < N; ++i)
        sum = frac_sum(sum, frac_arr[i]);
 
    printf("Sum of all fractions: %d/%d/n", sum.num, sum.den);
 
    return 0;
}
 
Fraction construct_fraction(int num, int den)
{
    Fraction result;
 
    if (den == 0)
    {
        num = 0;
        den = 1;
    }
 
    result.num = num;
    result.den = den;
 
    normalize_fraction(&result);
 
    return result;
}
 
int gcd(int a, int b)
{
    if (a == 0)
        return b;
 
    if (b == 0)
        return a;
 
    a = a > 0 ? a : -a;
    b = b > 0 ? b : -b;
 
    while (a != b)
    {
        if (a > b)
            a -= b;
        else
            b -= a;
    }
 
    return a;
}
 
void normalize_fraction(Fraction *frac)
{
    int d = gcd(frac->num, frac->den);
 
    frac->num /= d;
    frac->den /= d;
 
    if (frac->den < 0)
    {
        frac->den *= -1;
        frac->num *= -1;
    }
}
 
Fraction frac_sum(Fraction left, Fraction right)
{
    Fraction result = construct_fraction(left.num * right.den + left.den * right.num, left.den * right.den);
 
    normalize_fraction(&result);
 
    return result;
}
 
Текущее время: 02:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru