鱼C论坛

 找回密码
 立即注册
查看: 2866|回复: 4

[已解决]作业:求e的近似值,,我写不下去了

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

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

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

x




e的精确值等于下列无穷序列之和。

​0/!​​1​​+​1/!​​1​​+​2/!​​1​​+​3/!​​1​​+​4/!​​1​​+​5/!​​1​​+...

e0=​0/!​​1​​

e1=​0/!​​1​​+​1/!​​1​​

e2=​0/!​​1​​+​1/!​​1​​+​2/!​​1​​

e3=​0/!​​1​​+​1/!​​1​​+​2/!​​1​​+​3/!​​1​​

e4=​0/!​​1​​+​1/!​​1​​+​2/!​​1​​+​3/!​​1​​+​4/!​​1​​

输入一个浮点数error,计算误差在error范围内的常数e的近似值。可以通过产生系列近似值e0、e1、e2、....,直到当前的近似值与前一个近似值之间的误差不大于error。
输入格式:

输入一个浮点数error,表示误差
输出格式:

输出e的近似值
输入样例1:

在这里给出一组输入。例如:

0.01

输出样例1:

在这里给出相应的输出。例如:

2.7166666666666663

输入样例2:

在这里给出一组输入。例如:

0.000000001

输出样例2:

在这里给出相应的输出。例如:

2.7182818284467594
def factorial(num1):
    if num1 == 1:
        return 1
    else:
        return (num1 * factorial(num1 - 1))
def get_e(num2):
    if num2 == 1:
        return 1
    else:
        return ((1/factorial(num1) + get_e(num1)))
def keep_error(num1,num2,error):
    while abs(num1 - num2) > error:
        result = get_e(num2)
        print(result)
        
    
error = float(input())

num1 = 1
num2 = 2
keep_error(num1,num2,error)
最佳答案
2020-11-4 20:42:51
def fact(x):
#计算阶乘
    if x == 1 or x == 0:
        return 1
    else:
        return x*fact(x-1)

def run(x):
#ex计算
    if x == 0:
        return -1
    result = 0
    for each in range(x+1):
        result += 1/fact(each)
    return result

def check(x):
    i = 1
    while True:
        temp = run(i+1)
        print(i)
        temp2 = run(i)
        if temp - temp2 <= x:
            return temp
            break
        else:
            i += 1

msg = '请输入一个浮点数:'
while True:
    error = input(msg)
    #检查输入是否有误
    try:
        float(error)
    except:
        msg = '输入有误,请输入一个浮点数:'
        continue
    else:
        error = float(error)
        break
result = check(error)
print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-4 17:01:24 | 显示全部楼层
        楼主,把你的帖子整理一下,根本无法看清你列举的无限数列 e0、e1、e2、e3 、e4 究竟是什么内容。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-4 17:21:29 | 显示全部楼层
本帖最后由 jackz007 于 2020-11-4 23:01 编辑

        楼主试试这个代码,看看可以吗?
#-*-coding:gbk-*-
d = eval(input('计算精度:') . strip())
p , e , n = 1.0 , 1.0 , 1
while p < 1.0 / d : p , e , n = p * n , e + 1.0 / p / n , n + 1
print(e)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-4 20:42:51 | 显示全部楼层    本楼为最佳答案   
def fact(x):
#计算阶乘
    if x == 1 or x == 0:
        return 1
    else:
        return x*fact(x-1)

def run(x):
#ex计算
    if x == 0:
        return -1
    result = 0
    for each in range(x+1):
        result += 1/fact(each)
    return result

def check(x):
    i = 1
    while True:
        temp = run(i+1)
        print(i)
        temp2 = run(i)
        if temp - temp2 <= x:
            return temp
            break
        else:
            i += 1

msg = '请输入一个浮点数:'
while True:
    error = input(msg)
    #检查输入是否有误
    try:
        float(error)
    except:
        msg = '输入有误,请输入一个浮点数:'
        continue
    else:
        error = float(error)
        break
result = check(error)
print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-7 14:29:22 | 显示全部楼层
        建议楼主测试 3 楼的代码,运行结果可以与样例完全相吻合。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-17 23:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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