Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/8: Рейтинг темы: голосов - 8, средняя оценка - 5.00
2 / 1 / 1
Регистрация: 18.10.2016
Сообщений: 26

Реализовать класс для неправильных дробей

13.12.2016, 10:10. Показов 1569. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализовать класс для неправильных дробей. В этом классе реализовать интерфейс, содержащий методы для выполнения следующих операций:
1) сложение;
2) вычитание;
3) сокращение дроби.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.12.2016, 10:10
Ответы с готовыми решениями:

Создать класс для хранения обычных дробей
Здравствуйте, не могу решить задачу. Условие: Создать класс для хранения обычных дробей. Запрограммировать метод сокращения дроби....

Реализовать класс для матриц. В этом классе реализовать интерфейс, содержащий методы для выполнения операций
Реализовать класс для матриц. В этом классе реализовать интерфейс, содержащий методы для выполнения следующих операций: - сложение -...

Реализовать класс ModelWindow, добавив поле для курсора, используя для представления поля класс Cursor
Реализовать класс ModelWindow, добавив поле для курсора. Используйте для представления поля класс Cursor. (это под типом класс в классе).

2
Злой няш
 Аватар для I2um1
2136 / 1505 / 565
Регистрация: 05.04.2010
Сообщений: 2,881
13.12.2016, 10:26
Лучший ответ Сообщение было отмечено Pentuh Coder как решение

Решение

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
public class Rational
{
    public Rational(int numerator, int denominator)
    {
        Numerator = numerator;
        Denominator = denominator;
        Reduce();
    }
 
    public int Numerator { get; private set; }
    public int Denominator { get; private set; }
 
    public static Rational operator +(Rational a, Rational b)
    {
        int numerator = (a.Numerator * b.Denominator) + (a.Denominator * b.Numerator);
        int denominator = a.Denominator * b.Denominator;
        return new Rational(numerator, denominator);
    }
 
    public static Rational operator -(Rational a, Rational b)
    {
        int numerator = (a.Numerator * b.Denominator) - (a.Denominator * b.Numerator);
        int denominator = a.Denominator * b.Denominator;
        return new Rational(numerator, denominator);
    }
 
    private void Reduce()
    {
        int greatestCommonDivisor = GreatestCommonDivisor(Numerator, Denominator);
        Numerator /= greatestCommonDivisor;
        Denominator /= greatestCommonDivisor;
    }
 
    private static int GreatestCommonDivisor(int a, int b)
    {
        while (true)
        {
            if (b == 0) return a;
            int temp = a;
            a = b;
            b = temp % b;
        }
    }
}
На правильность не проверял.
0
309 / 309 / 215
Регистрация: 24.09.2013
Сообщений: 771
13.12.2016, 11:35
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
using System;
 
namespace Space
{
    class Program
    {
        static void Main(string[] args)
        {
            IrregularFraction a = new IrregularFraction(-8, 5);
            IrregularFraction b = new IrregularFraction(7, 3);
            Console.WriteLine(a.ToString());
            Console.WriteLine(b.ToString());
 
            IrregularFraction d = a.Sub(b);
            Console.WriteLine(d.ToString());
            Console.WriteLine(d.Reduce());
            Console.ReadLine();
        }
    }
 
    interface IIrregularFraction
    {
        IrregularFraction Sum(IrregularFraction a);
        IrregularFraction Sub(IrregularFraction b);
        int Reduce();
    }
 
    class IrregularFraction : IIrregularFraction
    {
        public int Numerator { get; private set; }
        public int Denominator { get; private set; }
 
        public IrregularFraction(int num, int denum)
        {
            if (num != 0 && denum != 0 && Math.Abs(num) >= Math.Abs(denum)) 
            {
                Numerator = num * denum < 0 ? -Math.Abs(num) : num;
                Denominator = Math.Abs(denum);
            }
            else
            {
                Console.WriteLine("Дробь не является неправильной. Взяты значения по умолчанию.");
                Numerator = 1;
                Denominator = 1;
            }
        }
 
        public IrregularFraction Sum(IrregularFraction a)
        {
            if (Denominator == a.Denominator)
                return new IrregularFraction(Numerator + a.Numerator, Denominator);
            int newDenum = NOD(Denominator, a.Denominator);
            int newNum = Numerator * newDenum / Denominator + a.Numerator * newDenum / a.Denominator;
            return new IrregularFraction(newNum, newDenum);
        }
 
        public IrregularFraction Sub(IrregularFraction a)
        {
            if (Denominator == a.Denominator)
                return new IrregularFraction(Numerator - a.Numerator, Denominator);
            int newDenum = NOD(Denominator, a.Denominator);
            int newNum = Numerator * newDenum / Denominator - a.Numerator * newDenum / a.Denominator;
            return new IrregularFraction(newNum, newDenum);
        }
 
        public int Reduce()
        {
            int iPart = Numerator / Denominator;
            Numerator = Numerator % Denominator;
            Console.WriteLine("{0}{1}{2}/{3}", iPart, Numerator >= 0 ? "+" : "", Numerator, Denominator);
            return iPart;
        }
 
        // В конкретно этой задаче НОД находится для знаменателей.
        // Поэтому этот метод работает только для положительных чисел, т.к. знаменатель всегда положительный.
        // В цикле не учитываются значения заменателя, равные нулю, ибо такие знаменатели отсеиваются при создании новой дроби.
        int NOD(int a, int b)
        {
            if (a == 1 || b == 1)
                return 1;
            for (int i = 2; i < a * b; i++)
                if (i % a == 0 && i % b == 0)
                    return i;
            return a * b;
        }
 
        public override string ToString()
        {
            return String.Format("{0}/{1}", Numerator, Denominator);
        }
    }
}
Добавлено через 1 минуту
I2um1, у вас нет интерфейса, который полагается по заданию.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.12.2016, 11:35
Помогаю со студенческими работами здесь

Реализовать класс Goods используя для представления цены класс Money
Реализовать класс Goods (пункт 1 ), используя для представления цены класс Money с пункта 2 Реализовать метод уценки товара, уменьшая цену...

Класс Matrix: реализовать шаблонный класс для двумерных массивов
Доброго времени суток. У меня вопрос: я создал класс Array со внутренним динамическим массивом и объекты этого типа смог создать и я ими...

Реализовать класс Triangle (задание 25), опираясь на класс Angle из задания 26 для представления углов
Реализовать класс Triangle (задание 25), опираясь на класс Angle из задания 26 для представления углов. Собственно вот такая проблема. Не...

Реализовать приложение "Калькулятор для обыкновенных дробей"
Реализовать приложение &quot;Калькулятор для обыкновенных дробей&quot;. Спроектировать и реализовать класс Обыкновенная дробь. С помощью данного...

Реализовать приложение "Калькулятор для обыкновенных дробей"
Здравствуйте! Необходимо реализовать приложение &quot;Калькулятор для обыкновенных дробей&quot;. Спроектировать и реализовать класс...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru