cs61a 2020 fall lab06

文章介绍了几个Python函数,包括递归函数`make_adder_inc`和`fib`用于生成Fibonacci数列,以及`insert_items`函数实现列表中插入元素。同时,代码示例展示了如何在列表中插入元素并保持列表结构不变。
摘要由CSDN通过智能技术生成
this_file = __file__


def make_adder_inc(a):
    """
    >>> adder1 = make_adder_inc(5)
    >>> adder2 = make_adder_inc(6)
    >>> adder1(2)
    7
    >>> adder1(2) # 5 + 2 + 1
    8
    >>> adder1(10) # 5 + 10 + 2
    17
    >>> [adder1(x) for x in [1, 2, 3]]
    [9, 11, 13]
    >>> adder2(5)
    11
    """
    "*** YOUR CODE HERE ***"
    def adder(b):
        nonlocal a 
        a = a + 1
        return  a + b -1 
    return adder


def make_fib():
    """Returns a function that returns the next Fibonacci number
    every time it is called.

    >>> fib = make_fib()
    >>> fib()
    0
    >>> fib()
    1
    >>> fib()
    1
    >>> fib()
    2
    >>> fib()
    3
    >>> fib2 = make_fib()
    >>> fib() + sum([fib2() for _ in range(5)])
    12
    >>> from construct_check import check
    >>> # Do not use lists in your implementation
    >>> check(this_file, 'make_fib', ['List'])
    True
    """
    "*** YOUR CODE HERE ***"
    pre ,curr = -1,1
    def fib():
        nonlocal pre ,curr
        pre , curr = curr , curr + pre
        return curr 
    return fib


def insert_items(lst, entry, elem):
    """
    >>> test_lst = [1, 5, 8, 5, 2, 3]
    >>> new_lst = insert_items(test_lst, 5, 7)
    >>> new_lst
    [1, 5, 7, 8, 5, 7, 2, 3]
    >>> large_lst = [1, 4, 8]
    >>> large_lst2 = insert_items(large_lst, 4, 4)
    >>> large_lst2
    [1, 4, 4, 8]
    >>> large_lst3 = insert_items(large_lst2, 4, 6)
    >>> large_lst3
    [1, 4, 6, 4, 6, 8]
    >>> large_lst3 is large_lst
    True
    """
    "*** YOUR CODE HERE ***"
  
    i = 0
    while i < len(lst) :
        if lst[i] == entry :
            lst.insert(i+1, elem)
            i = i + 2
        else :
            i = i + 1
    # for i in range(len(temp)):
    #     if temp[i] == entry :
    #         temp.insert(i+1, elem)
    #         i = i + 2
    
    return lst

CS61A 2020秋季学期的讨论课5主要涉及到关于递归的问题。这节讨论课中我们学习了递归函数的定义、调用和实例,并进行了一些练习。 首先,我们回顾了递归函数的定义。递归函数是指在一个函数的定义中调用了该函数本身的情况。这样的定义允许我们通过将问题分解为更小的子问题来解决复杂的问题。递归函数通常包括一个基本情况和一个递归情况。基本情况表示问题已经足够简单,可以直接计算出结果,而递归情况则表示将问题拆解为更小的子问题,并调用自身来解决这些子问题。 在练习中,我们通过编写递归函数来解决一系列问题。例如,我们实现了一个递归函数来计算一个列表的长度。首先,我们检查基本情况,即当列表为空时长度为0。然后,我们将问题拆解为子问题,即将列表分解为其第一个元素和其余部分。然后,我们递归地计算剩余部分的长度,并将其加上第一个元素,最终得到整个列表的长度。 在讨论课中,我们还学习了尾递归。尾递归是指递归函数中递归调用发生在函数的最后一步操作的情况。尾递归函数可以通过迭代的方式执行,而不会在每次递归调用时创建新的栈帧,从而减少了内存的使用。这对于处理大规模数据非常有用。 总而言之,本次讨论课中我们学习了递归函数的定义和使用。通过理解递归的原理和练习编写递归函数,我们能够更好地解决复杂的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值