这个Python年金函数在哪里出问题了?

时间:2019-09-22 09:34:28

标签: python finance calculation annuity

我有这个python函数,用于创建年金,其年金值每2年翻一番。我尝试了两种方法,第一种是递归的,但是我得到一个错误“比较中超出了最大递归深度”或类型为None(当我以annu(10000,40,0.1045)运行该函数时

def annu(MNY, n, i):
    k=MNY/i 
    c=((1+i)**(n-1))-1 
    FV=k*c
    FV1=0 
    FV2=0
    for y in range(1, n):
        if (y%2)==1:
            FV1=annu(MNY,(n),i)
            print('FV1 is', FV1)
            return round(FV1,3)
        else:
            FV2=2*FV1
            print('FV2 is', FV2)
            return round(FV2,2)
        FV=FV1+FV2
        inv_bal=FV
        return round(inv_bal,1)

第二个不涉及递归,但这给了我一个错误的答案:

def inp(PMT, n,i):
    balance=0
    FV1=0
    FV2=0

    k=PMT/i

    c=((1+i)**n)-1

    FV=k*c

    for j in range(0,n):


        if j%2==1:
            FV=2*((FV)*(1+i)**(n-1))
            interest=balance*i

            balance=balance+interest + PMT

            FV1=FV1+balance
            print('FV1 is', FV1)
         else:
            FV2=2*((FV1)*(1+i)**(n-1))
            interest=balance*i

            balance=balance+interest + PMT

            FV2=FV2+balance
            print('FV2 is', FV2)
            FV=FV1+FV2
            print('inv_bal', FV)
            inv_bal=FV

如果我将其作为annu(10000,40,0.1045)运行,我希望得到大约4 * 10 ** 9的答案

0 个答案:

没有答案