С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для sashqqqa
2 / 1 / 1
Регистрация: 22.03.2021
Сообщений: 9

Вычислите корень n-й степени из числа методом деления отрезка пополам

04.06.2023, 23:46. Показов 1106. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Деление пополам

Помогите, пожалуйста, решить эту задачу:

Дано действительное число a и натуральное n. Вычислите корень n-й степени из числа a.
Для решения используйте метод деления отрезка пополам.

Входные данные
На вход программе в первой строке подаётся действительное неотрицательное число a, не превосходящее 1000, заданное с точностью до 6 знаков после точки. Во второй строке — натуральное число n, не превосходящее 10.

Выходные данные
Программа должна вывести единственное число — ответ на задачу с точностью не менее 4 знаков после точки.


Ввод:
2
2


Вывод:
1.41421356237



Написал два варианта решения, но они проходят не по всем тестам:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
def main():
    num = float(input())
    rootDegree = int(input())
 
    eps = 0.00001
    root = num / rootDegree
    rn = num
    countiter = 0
 
    while abs(root - rn) >= eps:
        rn = num
        for i in range(1, rootDegree):
            rn = rn / root
        root = 0.5 * (rn + root)
        countiter += 1
 
    print(root)
 
if __name__ == "__main__":
    main()


Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def nth_root(a, n, precision=0.0001):
    left = 0
    right = max(1, a)
    mid = (left + right) / 2.0
    while abs(mid ** n - a) > precision:
        if mid ** n < a:
            left = mid
        else:
            right = mid
        mid = (left + right) / 2.0
    return mid
 
a = float(input())
n = int(input())
 
print(nth_root(a, n))
Добавлено через 1 час 0 минут
Все таки решил сам, вот код, возможно кому-то поможет:

Python
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
def root(a, n):
    def f(x):
        return x**n - a
 
    if a < 1:
        left = a
        right = 1
    else:
        left = 0
        right = a
    
    max_iterations = 100000
    current_iteration = 0
    while current_iteration < max_iterations:
        mid = (left + right) / 2
        if f(left) * f(mid) <= 0:
            right = mid
        else:
            left = mid
        if abs(right - left) < 0.000001:
            return round((left + right) / 2, 6)
        current_iteration += 1
    
    return "No root found in " + str(max_iterations) + " iterations."
 
a = float(input())
n = int(input())
print(root(a, n))
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.06.2023, 23:46
Ответы с готовыми решениями:

Найти корень уравнения методом деления отрезка пополам
Найти какой-нибудь корень уравнения 2*cos(5+x)–3sin(2–x)=0 на отрезке с заданной точностью E = 0.0001 методом половинного деления. ...

Вычислите корень n-й степени методом деления отрезка пополам
Дано действительное число a и натуральное n. Вычислите корень n-й степени из числа Для решения используйте метод деления отрезка...

Рекурсивная программа, которая методом деления отрезка пополам находит с точностью EPS корень уравнения
Напишите рекурсивную программу, которая по заданным A, B и EPS методом деления отрезка пополам находит с точностью EPS корень уравнения...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
04.06.2023, 23:46
Помогаю со студенческими работами здесь

Первый корень методом деления отрезка пополам, второй корень методом хорд, третий корень методом хорд и касательных
решить уравнение, первый корень методом деления отрезка пополам, второй корень методом хорд, третий корень смешанным методом хорд и...

Корень уравнения методом деления отрезка пополам
Здравствуйте. Помогите пожалуйста с задачей: Дано действительное положительное число (эпсилон). Методом деления отрезка пополам найти...

Найдите корень уравнения методом деления отрезка пополам
Найдите корень уравнения cos(x^5)+ x^4−345.3∗x−23=0 на отрезке с точностью по x не хуже, чем 0.001. Известно, что на этом промежутке...

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

Найти корень уравнения методом деления отрезка пополам
Найти корень уравнения методом деления отрезка пополам с точностью e=0.001 (рис. 6)


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «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-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru