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

Сократите дробь (функция)

28.08.2018, 20:07. Показов 68701. Ответов 8

Студворк — интернет-сервис помощи студентам
Доброго времени суток, возникла проблема с задачей:

"Даны два натуральных числа n и m.

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

Решение оформите в виде функции ReduceFraction(n, m), получающая значения n и m и возвращающей кортеж из двух чисел (return p, q)."

Задачу решила, код вроде работает, но проверку не проходит - требуется такой вывод:

Тест 1
Входные данные:
12
16

Вывод программы:
3 4

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

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def ReduceFraction(n, m):
    if n > m:
        k = n
    else:
        k = m
    while k != 1:
        if n % k == 0 and m % k == 0:
            return n // k, m // k
        else:
            k -= 1
    return n, m
 
 
n, m = int(input()), int(input())
print(ReduceFraction(n, m))
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.08.2018, 20:07
Ответы с готовыми решениями:

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

Функция преобразующая дробь к несократимому виду
В задаче нельзя использовать стандарт функции и дополнительные модули. Необходимо реализовать пользовательский алгоритм. Описать...

Сократите алгебраическую дробь
Сократите алгебраическую дробь:

8
165 / 114 / 59
Регистрация: 12.07.2018
Сообщений: 277
28.08.2018, 20:56
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
def ReduceFraction(n, m):
 if n > m:
  k = n
 else:
  k = m
 while k != 1:
  if n % k == 0 and m % k == 0:
   return n // k, m // k
  else:
   k -= 1
 return n, m
 
n, m = ReduceFraction(int(input()), int(input()))
print(n, m)
1
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
29.08.2018, 12:24
math.gcd поможет.
Что до вывода - уточните формат. По описанию требуется кортеж, но в выводе явно строка.
0
1 / 1 / 0
Регистрация: 11.11.2018
Сообщений: 17
13.11.2018, 10:29
Пожалуйста выложите полный код программы
0
208 / 95 / 15
Регистрация: 27.07.2018
Сообщений: 323
13.11.2018, 11:04
shadow2018,
Для сокращения дроби, используй, "Алгори́тм Евкли́да" - для нахождения общего делителя.
Далее каждую переменную дели на общий делитель, выводи через print(a, b).

Добавлено через 4 минуты
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)
Код рабочий, сам проверил.
Если помог не забудь нажать спасибо, отметить как лучший.
2
1 / 1 / 0
Регистрация: 11.11.2018
Сообщений: 17
13.11.2018, 13:07
Нужно использовать ReduceFraction(n, m)
0
0 / 0 / 0
Регистрация: 14.09.2021
Сообщений: 1
24.05.2022, 19:17
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def ReduceFraction(n, m):
    if n > m:
        k = n
    else:
        k = m
    while k != 1:
        if n % k == 0 and m % k == 0:
            return n // k, m // k
        else:
            k -= 1
    return n, m
 
 
n, m = int(input()), int(input())
print(*ReduceFraction(n, m)) #перед функцией поставь звёздочку, она распаковывает кортежи, списки
0
1712 / 579 / 76
Регистрация: 10.04.2009
Сообщений: 9,327
24.05.2022, 20:08
Python
1
2
3
4
import math
def reduce_fraction(n,m):
    k = math.gcd(n,m)
    return (n//k, m//k)
0
0 / 0 / 0
Регистрация: 31.05.2023
Сообщений: 1
31.05.2023, 09:47
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def ReduceFraction(n, m):
 if n > m:
  k = n
 else:
  k = m
 while k != 1:
  if n % k == 0 and m % k == 0:
   return n // k, m // k
  else:
   k -= 1
 return n, m
 
n, m = ReduceFraction(int(input()), int(input()))
if m==1:
    print(n)
else : 
    print(n,"/", m, sep="")
 
#Если сокращается до целого числа, выводит только целое число
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.05.2023, 09:47
Помогаю со студенческими работами здесь

Алгоритм Евклида - Сократите дробь
Дано натуральные числа a і b, которые обозначают числитель и знаменатель простой дроби. Сократите дробь, то-есть найдите такие натуральные...

Сократите дробь вида x/y, используя метод определения НОД(a, b)
Методы. Вызов метода Решить задачу используя вызов метода. Сократите дробь вида x/y, используя метод определения НОД(a, b). Определите...

Перемножить две рациональныу дроби, если результат является сократимой дробью, сократите эту дробь
Напишите программу умножения двух рациональных дробей. Если полученный результат является сократимой дробью, то сократите эту дробь. ...

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

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


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
[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
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru