С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/190: Рейтинг темы: голосов - 190, средняя оценка - 4.85
1 / 1 / 0
Регистрация: 11.11.2018
Сообщений: 17

Даны два натуральных числа n и m. Сократите дробь (n / m), то есть выведите два других числа p и q таких, что (n / m) =

13.11.2018, 11:11. Показов 36658. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Даны два натуральных числа n и m.
Сократите дробь (n / m), то есть выведите два других числа p и q таких, что (n / m) = (p / q) и дробь (p / q) — несократимая.
Решение оформите в виде функции ReduceFraction(n, m), получающая значения n и m и возвращающей кортеж из двух чисел (return p, q).

Ребят пожалуйста помогите решить задачу
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.11.2018, 11:11
Ответы с готовыми решениями:

Даны два натуральных числа n и m. Сократите дробь nm, то есть выведите два других числа p и q таких, что nm=qp
Даны два натуральных числа n и m. Сократите дробь nm, то есть выведите два других числа p и q таких, что nm=qp и дробь qp — несократимая. ...

Даны два натуральных числа a, b. Найти десятичную дробь, равную
Даны два натуральных числа a, b. Найти десятичную дробь, равную a/b, возможно - с периодом. Пример: 1/3= 0, (3) Именно чтобы период...

Даны два натуральных числа a и b, обозначающие соответственно числитель и знаменатель дроби. Сократить дробь, используя
Даны два натуральных числа a и b, обозначающие соответственно числитель и знаменатель дроби. Сократить дробь, используя функцию определения...

5
208 / 95 / 15
Регистрация: 27.07.2018
Сообщений: 323
13.11.2018, 11:29
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
a = int(input())
b = int(input())
 
v = a
g = b
while v != 0 and g != 0:
    if v > g:
        v = v % v
    else:
        g = g % v
 
if a == 0:
    c = v
    print(a // c, b // c)
else:
    c = g
    print(a // c, b // c)
Осталось сделать в роде функции, тут сам.
Если помог, не забудь нажать "Спасибо", отметить как лучший.
0
8 / 4 / 4
Регистрация: 17.09.2018
Сообщений: 20
13.11.2018, 12:59
Лучший ответ Сообщение было отмечено makishmaki как решение

Решение

Код корявый, при вводе 32 и 24 выдает 1 и 1

Добавлено через 12 минут
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
def ReduceFraction(n, m):
    p1 = max(n, m)
    p2 = min(n, m)
    if p1 == p2 and p1 * p2 != 0:
        return 1, 1
    else:
        p = p1 % p2
        while p>0:
            p1 = p2
            p2 = p
            p = p1 % p2
 
        return n // p2, m // p2
 
 
n = int(input())
m = int(input())
print(*ReduceFraction(n, m))
Такой код более менее правдоподобный результат дает

Добавлено через 1 минуту
тут использован алгоритм евклида для нахождения нод и сокращение обоих введенных чисел на него
1
1 / 1 / 0
Регистрация: 11.11.2018
Сообщений: 17
13.11.2018, 13:11  [ТС]
Спасибо большое, прошло!
0
1 / 1 / 0
Регистрация: 23.03.2020
Сообщений: 2
10.04.2020, 19:18
Python
1
2
3
4
5
6
7
8
9
10
11
12
def ReduceFraction(a, b):
    def gcd(a, b):
        if b == 0:
            return a
        else:
            return gcd(b, a % b)
    return a // gcd(a, b), b // gcd(a, b)
 
 
numenator = int(input())
denumenator = int(input())
print(*ReduceFraction(numenator, denumenator))
Как то так, на основе алгоритма Евклида
1
34 / 25 / 8
Регистрация: 16.11.2019
Сообщений: 179
10.04.2020, 22:13
Как по мне это самое простое и короткое решение:
Python
1
2
3
4
5
6
7
8
9
10
from math import gcd
 
def ReduceFraction(n, m):
    div = gcd(n, m)
    return n // div, m // div
 
 
n = int(input())
m = int(input())
print(ReduceFraction(n, m))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.04.2020, 22:13
Помогаю со студенческими работами здесь

Даны два натуральных числа m и n. Проверить, есть ли в записи числа m цифры, совпадающие с цифрами в записи числа n
1. Даны два натуральных числа m и n. Проверить, есть ли в записи числа m цифры, совпадающие с цифрами в записи числа n.

Даны два натуральных числа m и n. Проверить, есть ли в записи числа m цифры, совпадающие с цифрами в записи числа n
Вот сам код double n = Convert.ToDouble(textBox5.Text); double m = Convert.ToDouble(textBox4.Text); ...

Выведите два неотрицательных целых числа — x и x/10, таких, что их сумма в точности равна n
Заставили меня делать контест, к которому никакого интереса нет, не смог решить задачу с таким условием: Условие Известно, что...

Даны два числа А и В. Найти последовательность из n чисел (n дано) C1, C2, C3, … ,Cn, таких что C1 = А; C2 = C
Даны два числа А и В. Найти последовательность из n чисел (n дано) C1, C2, C3, … ,Cn, таких что C1 = А; C2 = C1 + d; C3 = C2 + 2d; C4 =...

Даны два натуральных числа m и n (m<= 9999, n<= 9999). Проверить, есть ли в записи числа m цифры, одинаковые с цифрами в
Буду благодарен!


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru