gif
Портал edu4cash: Что это и как работает?.
gif
Как быстро получить ответ от ИИ.
gif
Как задонатить в Roblox в России в 2024 году.
gif
Обновления на edu4cash – новые награды, улучшенная модерация и эксклюзивные возможности для VIP!.
  • Задать вопрос
  • Назад
  • Главная страница
  • Вопросы
  • Предметы
    • Русский язык
    • Литература
    • Математика
    • Алгебра
    • Геометрия
    • Вероятность и статистика
    • Информатика
    • Окружающий мир
    • География
    • Биология
    • Физика
    • Химия
    • Обществознание
    • История
    • Английский язык
    • Астрономия
    • Физкультура и спорт
    • Психология
    • ОБЖ
    • Немецкий язык
    • Французский язык
    • Право
    • Экономика
    • Другие предметы
    • Музыка
  • Темы
  • Банк
  • Магазин
  • Задания
  • Блог
  • Топ пользователей
  • Контакты
  • VIP статус
  • Пригласи друга
  • Донат
  1. edu4cash
  2. Вопросы
  3. Информатика
  4. 10 класс
  5. Как написать рекурсивную функцию harmonic(n), которая возвращает n-ое гармоническое число с точностью не менее 6 знаков после десятичной точки, используя формулу Hn = 1 + 1/2 + 1/3 + ... + 1/n? Функция будет вызываться следующим образом: n = int(input...
Задать вопрос
shyann75

2024-11-28 02:30:24

Как написать рекурсивную функцию harmonic(n), которая возвращает n-ое гармоническое число с точностью не менее 6 знаков после десятичной точки, используя формулу Hn = 1 + 1/2 + 1/3 + ... + 1/n?

Функция будет вызываться следующим образом:

n = int(input())
print(harmonic(n))

Важно! На проверку отправляем только функцию.

Формат входных данных

С клавиатуры вводится целое число n (1 ≤ n < 100) — аргумент функции harmonic.

Формат выходных данных

Одно вещественное число — результат вызова функции.

Примечания

В этой задаче запрещено использовать циклы!

Примеры

ВХОДНЫЕ ДАННЫЕ
1
2
ВЫХОДНЫЕ ДАННЫЕ
1.0
1.5

Информатика 10 класс Рекурсивные функции рекурсивная функция гармоническое число функция harmonic информатика точность 6 знаков формула Hn Python без циклов входные данные выходные данные Новый

Ответить

Born

2024-11-28 02:30:32

Чтобы написать рекурсивную функцию harmonic(n), которая вычисляет n-ое гармоническое число, мы будем использовать определение гармонического числа:

  • Hn = 1 + 1/2 + 1/3 + ... + 1/n

Рекурсивная функция будет работать следующим образом:

  1. Если n равно 1, то возвращаем 1.0, так как H1 = 1.
  2. В противном случае, функция должна возвращать 1/n + harmonic(n-1). Это означает, что мы добавляем 1/n к гармоническому числу для n-1.

Теперь давайте напишем саму функцию:

def harmonic(n):
    if n == 1:
        return 1.0
    else:
        return 1/n + harmonic(n-1)

Эта функция будет вызываться так:

n = int(input())
print(harmonic(n))

Теперь давайте разберем, как работает наш код:

  • Когда мы вызываем harmonic(n), если n равно 1, функция возвращает 1.0.
  • Если n больше 1, функция вызывает саму себя с аргументом n-1 и добавляет к результату 1/n.
  • Это продолжается до тех пор, пока не дойдем до базового случая, когда n равно 1.

Таким образом, мы получаем гармоническое число Hn с необходимой точностью, так как Python по умолчанию поддерживает вещественные числа с высокой точностью.


shyann75 ждет твоей помощи!

Ответь на вопрос и получи 34 Б 😉
Ответить

  • Политика в отношении обработки персональных данных
  • Правила использования сервиса edu4cash
  • Правила использования файлов cookie (куки)

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

Copyright 2024 © edu4cash

Получите 500 балов за регистрацию!
Регистрация через ВКонтакте Регистрация через Google

...
Загрузка...
Войти через ВКонтакте Войти через Google Войти через Telegram
Жалоба

Для отправки жалобы необходимо авторизоваться под своим логином, или отправьте жалобу в свободной форме на e-mail [email protected]

  • Карма
  • Ответов
  • Вопросов
  • Баллов