鱼C论坛

 找回密码
 立即注册
查看: 1842|回复: 1

递归问题求解

[复制链接]
发表于 2023-4-16 11:04:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
以下函数用于可用于求方程的近似解,其中参数f为一个输入、输出均为数字的函数


def solve(f, x1, x2):

    mid = (x1 + x2) / 2

    if f(mid) == 0 or abs(x1 - x2) < 1e-8:

        return # <A>

    elif f(mid) * f(x1) > 0:

        return # <B>

    else:

        return # <C>

如何补全该函数使其可以正常使用?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-4-16 11:13:35 | 显示全部楼层
要补全这个函数,您需要在每个返回语句中递归地调用 solve 函数。这是一个使用二分法求解方程的函数。函数 f 是一个一元方程,x1 和 x2 分别是搜索区间的上下限。下面是补全后的代码:
def solve(f, x1, x2):

    mid = (x1 + x2) / 2

    if f(mid) == 0 or abs(x1 - x2) < 1e-8:

        return mid

    elif f(mid) * f(x1) > 0:

        return solve(f, mid, x2)

    else:

        return solve(f, x1, mid)

在这个补全的版本中,当满足某个终止条件时(f(mid) == 0 或者 abs(x1 - x2) < 1e-8),函数将返回当前计算的中点 mid。否则,函数将在适当的子区间上递归调用自身。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-23 17:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表