zoukankan      html  css  js  c++  java
  • 4.Rabbits and Recurrence Relations

    Problem

    A sequence is an ordered collection of objects (usually numbers), which are allowed to repeat. Sequences can be finite or infinite. Two examples are the finite sequence (π,2–√,0,π)(π,−2,0,π) and the infinite sequence of odd numbers (1,3,5,7,9,)(1,3,5,7,9,…). We use the notation anan to represent the nn-th term of a sequence.

    A recurrence relation is a way of defining the terms of a sequence with respect to the values of previous terms. In the case of Fibonacci's rabbits from the introduction, any given month will contain the rabbits that were alive the previous month, plus any new offspring. A key observation is that the number of offspring in any month is equal to the number of rabbits that were alive two months prior. As a result, if FnFn represents the number of rabbit pairs alive after the nn-th month, then we obtain the Fibonacci sequence having terms FnFn that are defined by the recurrence relation Fn=Fn1+Fn2Fn=Fn−1+Fn−2 (with F1=F2=1F1=F2=1 to initiate the sequence). Although the sequence bears Fibonacci's name, it was known to Indian mathematicians over two millennia ago.

    When finding the nn-th term of a sequence defined by a recurrence relation, we can simply use the recurrence relation to generate terms for progressively larger values of nn. This problem introduces us to the computational technique of dynamic programming, which successively builds up solutions by using the answers to smaller cases.

    Given: Positive integers n40n≤40 and k5k≤5.

    Return: The total number of rabbit pairs that will be present after nn months, if we begin with 1 pair and in each generation, every pair of reproduction-age rabbits produces a litter of kk rabbit pairs (instead of only 1 pair).

    Sample Dataset

    5 3
    

    Sample Output

    19

    ###Rabbits and Recurrence Relations ###
    def fib(n,k):
        a, b = 1, 1
        for i in range (2,int(n)):
            a, b = b, int(k)*a + b #只需要保存最近两个月的数量即可
        print  b
        
    if __name__ == "__main__":
        fh = open ("C:\Users\hyl\Desktop\rosalind_fib.txt")
        l = fh.readline().split(' ')
        n, k = l[0], l[1]   
        fib(n,k)
    

      

  • 相关阅读:
    Vue组件
    Vue内置指令
    [vue插件]基于vue2.x的电商图片放大镜插件
    Vue过渡与动画
    一个 VUE 组件:实现子元素 scroll 父元素容器不跟随滚动(兼容PC、移动端)
    ORM进阶之Hibernate中对象的三大状态解析
    jQuery的CSS操作
    SqlCommand.DeriveParameters failed
    Web Service学习-CXF开发Web Service实例demo(一)
    去哪网实习总结:如何配置数据库连接(JavaWeb)
  • 原文地址:https://www.cnblogs.com/ylHe/p/6178312.html
Copyright © 2011-2022 走看看