Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.65/34: Рейтинг темы: голосов - 34, средняя оценка - 4.65
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143

Создать класс рациональных чисел и сравнить их

20.11.2018, 16:10. Показов 7348. Ответов 68
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
как создать класс рациональных чисел и сравнить их
нужно например 1/2+2/3=7/6
и 1/2<2/3
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2018, 16:10
Ответы с готовыми решениями:

Класс: Создать класс дробь - рациональных чисел, являющихся отношением двух целых чисел...
Создать класс дробь - рациональных чисел, является отношением двух целых чисел. Определить необходимые методы, конструкторы, деструкторы....

Создать класс рациональных дробей
Создать класс рациональных дробей, выбрав для него необходимые поля. Выделение целой части в классе реализовывать не нужно. Создать...

Описать класс дробей — рациональных чисел, являющихся отношением двух целых чисел
Описать класс дробей — рациональных чисел, являющихся отношением двух целых чисел.Предусмотреть методы сложения, вычитания, умножения и...

68
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143
22.11.2018, 02:20  [ТС]
Студворк — интернет-сервис помощи студентам
Элд Хасп, понял) ну можно попробовать

Добавлено через 10 минут
и еще можете проверить как работает деление , просто если вводить одинаковые дроби то как то не так считает по моему
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16150 / 11271 / 2890
Регистрация: 21.04.2018
Сообщений: 33,145
Записей в блоге: 2
22.11.2018, 12:32
Цитата Сообщение от volo_D9 Посмотреть сообщение
можно попробовать

и еще можете проверить как работает деление , просто если вводить одинаковые дроби то как то не так считает по моему
Перепроверьте. Ошибки, что нашёл исправил. Добавил:
- реализацию IComparable - теперь можно сортировать в списках, массивах
- вывод ToString с выделением целой части
- методы парсинга Parse и TryParse
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
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
    #region Класс для рациональных чисел
    public class RationalNumber : IComparable
    {
        /// <summary>Числитель</summary>
        public int Numerator { get; private set; }
        /// <summary>Знаменатель</summary>
        public uint Denominator { get; private set; }
        /// <summary>Десятично-дробное представление</summary>
        public double Rational { get { return ((double)Numerator) / ((double)Denominator); } }
 
        /// <summary>Конструктор с двумя параметрами</summary>
        /// <param name="Numerator">Числитель</param>
        /// <param name="Denominator">Знаменатель</param>
        public RationalNumber(int Numerator, uint Denominator)
        {
            if (Denominator == 0)
                throw new Exception("Знаменатель не может быть равен нулю!");
            uint gcd = 1;
            if (Numerator == 0)
            {
                this.Numerator = 0;
                this.Denominator = 1;
                return;
            }
            if (Numerator > 0)
                gcd = GCD((uint)Numerator, Denominator);
            else
                gcd = GCD((uint)-Numerator, Denominator);
            this.Numerator = Numerator / ((int)gcd);
            this.Denominator = Denominator / gcd;
        }
 
        #region Секция объявления преобразований типов
        /// <summary>Неявное преобразование в тип double</summary>
        /// <param name="r1">Исходное число типа RationalNumber</param>
        public static implicit operator double(RationalNumber r1) { return r1.Rational; }
 
        /// <summary>Неявное преобразование в тип RationalNumber</summary>
        /// <param name="r1">Исходное число типа Integer</param>
        public static implicit operator RationalNumber(int r1) { return new RationalNumber(r1, 1); }
        #endregion
 
        #region Секция переопределения арифметических операторов
        public static RationalNumber operator +(RationalNumber r1, RationalNumber r2)
        {
            return new RationalNumber
                (
                    (int)(r1.Numerator * r2.Denominator + r2.Numerator * r1.Denominator),
                    r1.Denominator * r2.Denominator
                );
        }
        public static RationalNumber operator *(RationalNumber r1, RationalNumber r2)
        {
            return new RationalNumber
                (
                    (int)(r1.Numerator * r2.Numerator),
                     (uint)(r1.Denominator * r2.Denominator)
                );
        }
        public static RationalNumber operator -(RationalNumber r1, RationalNumber r2)
        {
            return r1 + (-1 * r2);
        }
        public static RationalNumber operator /(RationalNumber r1, RationalNumber r2)
        {
            return r1 * (r2.Numerator < 0
                ? new RationalNumber((int)-r2.Denominator, (uint)-r2.Numerator)
                : new RationalNumber((int)r2.Denominator, (uint)r2.Numerator));
        }
        #endregion
 
        #region Секция переопределения операторов сравнения
        public static bool operator >(RationalNumber r1, RationalNumber r2)
        {
            return (r1 - r2).Numerator > 0;
        }
        public static bool operator <(RationalNumber r1, RationalNumber r2)
        {
            return (r1 - r2).Numerator < 0;
        }
        public static bool operator ==(RationalNumber r1, RationalNumber r2)
        {
            return (r1 - r2).Numerator == 0;
        }
        public static bool operator <=(RationalNumber r1, RationalNumber r2)
        {
            return !(r1 > r2);
        }
        public static bool operator >=(RationalNumber r1, RationalNumber r2)
        {
            return !(r1 < r2);
        }
        public static bool operator !=(RationalNumber r1, RationalNumber r2)
        {
            return !(r1 == r2);
        }
        #endregion
 
        #region Секция статических методов
        /// <summary>Статический метод возвращающий НОД двух положительных чисел</summary>
        /// <param name="A">Первое число</param>
        /// <param name="B">Второе число</param>
        /// <returns>Ноль - если оба чисела равно нулю, в остальных случаях НОД</returns>
        public static uint GCD(uint A, uint B)
        {
            uint C = A;
            A = A > B ? A : B;
            B = C > B ? B : C;
            C = A % B;
            if (C == 0) return B;
            return GCD(B, C);
        }
 
        /// <summary>Парсер из string</summary>
        /// <param name="s">Значение в формате string "-1 2/3" или "-2/3"</param>
        /// <returns>Новый объект RationalNumber инициализированный из строки</returns>
        public static RationalNumber Parse(string s)
        {
            string[] strArr = s.Split();
            if (strArr.Length > 2)
                throw new Exception("Строка не верного формата");
            if (strArr.Length == 2)
            {
                int intPart = int.Parse(strArr[0]);
                strArr = strArr[1].Split('/');
                uint den = uint.Parse(strArr[1]);
                return new RationalNumber((int)(intPart * den + (intPart >= 0 ? 1 : -1) * int.Parse(strArr[0])), den);
            }
            strArr = strArr[0].Split('/');
            return new RationalNumber(int.Parse(strArr[0]), uint.Parse(strArr[1]));
        }
 
        /// <summary>Парсер из string с проверкой на ошибку</summary>
        /// <param name="s">Значение в формате string "-1 2/3" или "-2/3"</param>
        /// <param name="result">Новый объект RationalNumber инициализированный из строки. Елси ошибка - возвращает 0/1</param>
        /// <returns>True, если преобразование возможно</returns>
        public static bool TryParse(string s, out RationalNumber result)
        {
            result = new RationalNumber(0, 1);
            string[] strArr = s.Split();
            if (strArr.Length > 2)
                return false;
            if (strArr.Length == 2)
            {
                if (!int.TryParse(strArr[0], out int intPart))
                    return false;
                strArr = strArr[1].Split('/');
                if (!uint.TryParse(strArr[0], out uint num))
                    return false;
                if (!uint.TryParse(strArr[1], out uint den))
                    return false;
                long numL = intPart * den + (intPart >= 0 ? 1 : -1) * num;
                if (numL > int.MaxValue || numL < int.MinValue)
                    return false;
                result = new RationalNumber((int)numL, den);
                return true;
            }
            {
                strArr = strArr[0].Split('/');
                if (!int.TryParse(strArr[0], out int num))
                    return false;
                if (!uint.TryParse(strArr[1], out uint den))
                    return false;
                result = new RationalNumber(num, den);
                return true;
            }
        }
        #endregion
 
        #region Секция переопределения методов Equals, GetHashCode и ToString
        public override bool Equals(object obj)
        {
            if (!(obj is RationalNumber))
            {
                return false;
            }
 
            var number = (RationalNumber)obj;
            return Numerator == number.Numerator &&
                   Denominator == number.Denominator;
        }
 
        public override int GetHashCode()
        {
            var hashCode = -1534900553;
            hashCode = hashCode * -1521134295 + Numerator.GetHashCode();
            hashCode = hashCode * -1521134295 + Denominator.GetHashCode();
            return hashCode;
        }
 
        public override string ToString()
        {
            if (Numerator == 0) return "0";
            int sign;
            uint num;
            if (Numerator < 0)
            {
                sign = -1;
                num = (uint)-Numerator;
            }
            else
            {
                sign = 1;
                num = (uint)Numerator;
 
            }
            uint intPart = num / Denominator;
            num %= Denominator;
            string ret = "";
            if (sign < 0) ret = "-";
            if (intPart > 0) ret += intPart + " ";
            if (num > 0)
                return ret + $"{num}/{Denominator}";
            else
                return ret.Trim();
        }
        #endregion
 
        /// <summary>Реализация интерфейса IComparable</summary>
        /// <param name="obj">Объект типа RationalNumber сравниваемый с текущим</param>
        /// <returns>Значение сравнения с obj: 1 если больше, 0 если равно и -1 если меньше</returns>
        public int CompareTo(object obj)
        {
            if (obj is RationalNumber rat)
                return Rational.CompareTo(rat.Rational);
            return 0;
        }
 
    }
    #endregion
0
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143
22.11.2018, 14:43  [ТС]
Элд Хасп, нужно 17 скачать и там все делать) какую лучше :?

сообщество

Professional

Корпоративные

Добавлено через 6 секунд
Элд Хасп, нужно 17 скачать и там все делать) какую лучше :?

сообщество

Professional

Корпоративные
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16150 / 11271 / 2890
Регистрация: 21.04.2018
Сообщений: 33,145
Записей в блоге: 2
22.11.2018, 15:08
Цитата Сообщение от volo_D9 Посмотреть сообщение
нужно 17 скачать и там все делать) какую лучше :?
Бесплатная там только одна - сообщество
0
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143
22.11.2018, 17:20  [ТС]
Элд Хасп, хорошо, ее установлю ) потом скажу как все работает)

Добавлено через 2 часа 3 минуты
Элд Хасп, да на 17 все идеально работает) спасибо
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16150 / 11271 / 2890
Регистрация: 21.04.2018
Сообщений: 33,145
Записей в блоге: 2
22.11.2018, 17:26
Цитата Сообщение от volo_D9 Посмотреть сообщение
а 17 все идеально работает) спасибо
Удачи!

Добавлено через 2 минуты
В 2017 все однострочные методы типа
C#
85
86
87
88
        public static bool operator <=(RationalNumber r1, RationalNumber r2)
        {
            return !(r1 > r2);
        }
Запишите так
C#
85
        public static bool operator <=(RationalNumber r1, RationalNumber r2) =>!(r1 > r2);
Добавлено через 2 минуты
Однострочные свойства для чтения тоже перепишите
C#
8
9
        /// <summary>Десятично-дробное представление</summary>
        public double Rational { get { return ((double)Numerator) / ((double)Denominator); } }
Должно быть так
C#
8
9
        /// <summary>Десятично-дробное представление</summary>
        public double Rational =>((double)Numerator) / ((double)Denominator);
0
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143
22.11.2018, 19:12  [ТС]
Элд Хасп, да , хорошо) спасибо

Добавлено через 3 минуты
а вы в питоне разбираетесь ?
0
Модератор
Эксперт .NET
 Аватар для Элд Хасп
16150 / 11271 / 2890
Регистрация: 21.04.2018
Сообщений: 33,145
Записей в блоге: 2
22.11.2018, 19:22
Цитата Сообщение от volo_D9 Посмотреть сообщение
а вы в питоне разбираетесь ?
Нет. Кроме названия ничего не знаю.
0
-3 / 2 / 0
Регистрация: 14.10.2015
Сообщений: 143
22.11.2018, 20:25  [ТС]
Элд Хасп, понял, спасибо еще раз за все) очень выручили
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.11.2018, 20:25
Помогаю со студенческими работами здесь

Описать класс дробей-рациональных чисел, являющихся отношением двух целых чисел
Описать класс дробей-рациональных чисел, являющихся отношением двух целых чисел. Предусмотреть методы сложения, вычитания, умножения и...

Описать класс дробей — рациональных чисел, являющихся отношением двух целых чисел
Помогите,пожалуйста.. 1)В одномерном массиве, состоящем из п вещественных элементов, вычислить: • количество элементов массива, равных...

Описать класс дробей — рациональных чисел, являющихся отношением двух целых чисел
Каждый разрабатываемый класс должен, как правило, содержать следующие элементы: скрытые поля, конструкторы с параметрами и без параметров,...

Описать класс дробей рациональных чисел
Как описать класс дробей рациональных чисел, являющихся отношением двух целых чисел. Предусмотреть методы сложения, вычитания, умножения...

Определить класс для рациональных чисел
Начало изучения понятия класса и объекта в С++, для меня много не ясного. Помогите, пожалуйста. Задача: необходимо Определить класс...


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

Или воспользуйтесь поиском по форуму:
69
Ответ Создать тему
Новые блоги и статьи
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru