python23:二分法求函数的零点

【问题描述】

现有方程:f(x) = x5-15x4+85x3-225x2+274x-121, 已经f(x)在[1.5,2.4]区间有且只有一个根,用二分法求解该根。

【输入形式】

输入一个正整数n,当f(x)值小于10-n时认为函数值为0

【输出形式】

输出方程在[1.5,2.4]区间的根,精确到小数点后第6位

【样例输入】

9
【样例输出】

1.849016

【样例说明】
【评分标准】

# 求函数值
def fun(x):
    return x ** 5 - 15 * x ** 4 + 85 * x ** 3 - 225 * x ** 2 + 274 * x - 121


n = int(input())
if fun(1.5) < 0:
    low, high = 1.5, 2.4
else:
    low, high = 2.4, 1.5

# a为函数值小于0的端点,b为函数值大于0的端点

# f(mid)>0,大于0的一端(b)-->mid
# f(mid)<0,小于0的一端(a)-->mid
while True:
    mid = (low + high) / 2
    if fun(mid) < 0:
        low = mid
    elif fun(mid) > 0:
        high = mid
    elif abs(fun(mid)) < 10 ** (-n):         # abs(),取绝对值
        break

print("{:.6f}".format(mid))

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值