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

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

04.06.2023, 23:46. Показов 1139. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[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-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru