python 递归的思想

什么是递归?

  • 递归是自己调自己,但需要分解参数;
  • 需要一个递归出口返回
def fact(n):
       if n == 0:
           return 1
        else:
           return n*fact(n-1)
print(fact(0))
=====================
1.递归必须包含一个基本的出口(base case),
  否则就会无限递归,最终导致栈溢出。
  比如这里就是n==0返回1

2.递归必须包含一个可以分解的问题(recursive case).
  要想求得fact(n),就需要用 n*fact(n-1)

3.递归必须要向着递归出口靠近(toward the base case).
  这里每次递归调用都会n-1,向着递归出口n==0靠近

实战---实现报数:
给定一个正整数 n(1 ≤ n ≤ 30),输出报数序列的第 n 项。
注意:整数顺序将表示为一个字符串。

题目

代码实现:

# -*- coding:utf-8 -*-

class Solution(object):
    def countAndSay(self,n):
        if n == 1:
            return "1"
        return self.bs(self.countAndSay(n-1))

    def bs(self,string):
        lis = list(string)
        # 末尾补一个,方便后续计数
        lis.append('0')
        list1=[]
        re = 0
        i = 0
        while i<len(lis)-1:
            if lis[i] != lis[i+1]:
                list1.append(str(i+1-re))
                list1.append(lis[I])
                re = I+1
            i = I+1
        s = ''.join(list1)  #;列表转为字符串
        return s


if __name__ == "__main__":
    s = Solution()
    n= 4
    r = s.countAndSay(n)
    print r
======================
输出
1211
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1)这本书为什么值得看: Python语言描述,如果学的Python用这本书学数据结构更合适 2016年出版,内容...
    孙怀阔阅读 14,339评论 0 15
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 9,992评论 0 5
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 9,043评论 0 2
  • 说明: 本文中出现的所有算法题皆来自牛客网-剑指Offer在线编程题,在此只是作为转载和记录,用于本人学习使用,不...
    秋意思寒阅读 4,855评论 1 1
  • 不贪恋温暖的被窝 不沉迷娱乐的世界 不看中眼前的利益 不苟且卑微的偷生 翱翔蓝天是你追寻的目标 滚滚历史的风云中 ...
    杖剑走四方阅读 3,222评论 0 7

友情链接更多精彩内容