递归与循环

实例1:斐波那契数列

# 1 1 2 3 5 8 13
# 计算n位的数vi
def fibo(n):
    if n <= 2:
        return 1
    return fibo(n - 1) + fibo(n - 2)

#计算比n小的最大数是数列中的第几位
print(fibo(n))
def func(m):
    n = 1
    while True:
        # if fibo(n) > m and fibo(n - 1) < m:
        if fibo(n + 1) > m >= fibo(n):
            return n
        else:
            n += 1
def fib(n):
    f1 = f2 = 1
    for i in range(2, n):
        f1, f2 = f2, (f2 + f1)
    return f2


def fib_n(n):
    if n <= 2:
        return 1
    return fib_n(n-1) + fib_n(n-2)

 

实例二:计算路径中总文件的大小

递归

# 用递归方法计算文件夹的大小
def cal_size(file_path):
    file_size = 0
    file_name = os.listdir(file_path)
    for name in file_name:
        name_path = os.path.join(file_path, name)
        if os.path.isdir(name_path):
            file_size += cal_size(name_path)
        else:
            file_size += os.path.getsize(name_path)
    return file_size


print(cal_size("H:\GamePatch"))

循环方法:

lst = ["H:\GamePatch", ]
file_size = 0
while lst:
    file_name = lst.pop()
    file_path = os.listdir(file_name)
    for name in file_path:
        name_new = os.path.join(file_name, name)
        if os.path.isdir(name_new):
            lst.append(name_new)
        else:
            file_size += os.path.getsize(name_new)
print(file_size)

 

转载于:https://www.cnblogs.com/jiaqi-666/p/9513545.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值