递归

简介: 递归
#  递归是一种编程思想
# 递归的特点:
    # 函数内部自己调用自己
    # 必须有出口
# 应用:3以内数字累加和
    # 需求:3以内数字累加和 3+2+1
    # 6 = 3 + 2以内数字累加和
    # 2以内数字累加和 = 2 + 1以内数字累加和
    # 1以内数字累加和  = 1 (出口)
def sum_number(num):
    # 2.出口
    if num == 1:
        return 1
    # 1.当前数字 + 当前数字-1的累加和
    return num + sum_number(num-1)


result = sum_number(3)
print(result)
相关文章
|
25天前
递归
【10月更文挑战第23天】递归。
14 4
|
6月前
|
算法 C#
C#递归详解
C#递归详解
51 0
|
JavaScript 前端开发
什么是递归?
什么是递归?
107 0
|
存储 算法 C++
递归的应用
递归的应用
|
Java 数据安全/隐私保护 决策智能
字符串全排列(递归)
字符串全排列,递归的应用
156 0
|
算法 索引
第 6 章 递归
简单的说: 递归就是方法自己调用自己,每次调用时传入不同的变量,递归有助于编程者解决复杂的问题,同时可以让代码变得简洁。
68 0
|
机器学习/深度学习 算法
『递归』整数划分
根据n和m的关系,考虑一下几种情况: (一)当n==1时,无论m的值为多少 ,只有一种划分,即{1} (二)当m==1 时,无论n的值为多少,只有一种划分,即1个n,{n} 。 (三)当n==m时,根据划分中是否包含n,可以分为以下两种情况: (1)划分中包含n的情况,只有一个,即 {n} (2)划分中不包含n的情况,这时划分中最大的数字也一定比n小,即n的所有(n-1)划分,即q(n,n-1)。 因此q(n,m)=1+q(n,n-1) (四)当n<m时,由于划分中不可能出现负数,因此就相当于q(n,n) (五)当n>m 时,根据划分中是否包含最大值m,可以分为以下两种情况:
169 0