递归应用

1.理解

百科:一种计算过程,如果其中每一步都要用到前一步或前几步的结果,称为递归的;

理解:函数调用自己的过程,这类函数处理的事情具有重复性,处理此类实行可用while或者for,但结构上不够简便;

关注项:

1)如果采用递归求解一个重复过程的结果,需要知道何时结束,不能一直调用自己,所以引用了“基线条件”和“递归条件”;当满足基线条件时停止调用函数本身,结束递归;

2)递归过程数据调用采用“”的形式,即先进后出

扩展:

D&C(Divide and Conquer)分而治之:一种递归式的问题解决方法,对解决递归问题提供了方法;D&C解决递归问题的过程:

1)找出基线条件,该条件必须尽可能简单;

2)不断将问题分解或缩小规模,直到符合基线条件;

2.场景应用

来自聊天中的需求:

对需求进行分析,必须用10元钱取买酒才会获得瓶子,获得瓶子就会获得瓶盖和空瓶子,瓶盖和空瓶反过来获得酒,酒在获得空瓶和瓶盖,所以最后的问题就是酒和空瓶、瓶盖的来回“兑换”问题,所以该问题属于递归问题;

根据解决递归的方法,找出递归条件和基线条件,其实递归条件和基线条件已经体现在了需求中,即瓶盖和空瓶的数量;

1)基线条件确定

瓶盖数caps<4 & 空瓶数emptys<2

2)递归条件确定

瓶盖数caps≥4 & 空瓶数emptys≥2

3.功能实现

3.1)Python 递归

import math
def Drink(money,price):
global caps,emptys,out
caps = 0
emptys = 0
out = []#定义缓存,用于存放每次兑换喝的酒
if money >= 2:
out.append(math.floor(money/price)) #整除2,看够不够买酒钱
caps = out[0]
emptys = out[0]
rec(caps,emptys)
num = sum(out) #计算喝酒总量
return num def Caps(total_caps):
left_caps = total_caps % 4 #获取剩余的瓶盖
out2 = math.floor(total_caps/4) #瓶盖兑换后的酒的个数
return(out2,left_caps) def Emptys(total_emptys):
left_emptys = total_emptys % 2 #获取剩余的空瓶
out3 = math.floor(total_emptys/2) #空瓶兑换后的酒的个数
return(out3,left_emptys) def rec(caps,emptys):
if caps >= 4 or emptys >= 2: #递归条件条件,也是基线条件
if caps >= 4:
out2, left_caps = Caps(caps)
caps = out2 + left_caps
emptys = emptys + out2 #兑换的酒累加到空瓶中
out.append(out2)
if emptys >= 2:
out3, left_emptys = Emptys(emptys)
emptys = out3 + left_emptys
caps = caps + out3 #兑换的酒累加到瓶盖中
out.append(out3)
return rec(caps,emptys)
else: #基线条件退出 ,返回递归结果
return out print ('You Can Use','','RMB',' drinking',Drink(10,2),"bottles drink" )

运行结果:

You Can Use 10 RMB  drinking  bottles drink

小结:

1)在python中定义空列表:var=[] ,在对var赋值时可以通过var.append(value),直接赋值,索引位置会根据增加的变量自动往后移;

2)  在python中取余用 % 号,向下取整需要调用math库,函数与matlab一样的floor;

3)递归函数是rec(caps,emptys),该函数被Drink函数调用,将最初的10元钱获取的瓶盖和空瓶传递过去,统一了变量,即可进行递归应用;

3.2)Matlab While循环

function [num] = Drink(money,price)
global caps emptys
caps = 0;
emptys = 0;
t = 0;
out = [];
out2 = 0;
out3 = 0;
if money>=2
t = +1;
out(t,1) = floor(money/price);
end
caps = out(t,1);
emptys = out(t,1);
while caps>=4|emptys>=2
if caps>=4
[out2,left_caps] = Caps(caps);
caps = out2+left_caps;
emptys = emptys+out2;
t = t+1;
out(t,1) = out2;
end
if emptys>=2
[out3,left_emptys] = Emptys(emptys);
emptys = out3 + left_emptys;
caps = caps+out3;
t = t+1;
out(t,1) = out3;
end
end
num = sum(out); function [out2,left_caps] = Caps(total_caps)
if total_caps >= 4
left_caps = mod(total_caps,4);
out2 = floor(total_caps/4);
end function [out3,left_emptys] = Emptys(total_emptys)
if total_emptys >= 2
left_emptys = mod(total_emptys,2);
out3 = floor(total_emptys/2);
end

运行结果与Python一致;

小结:

1)mod取余,计算剩余的空瓶或瓶盖;

2)利用floor函数计算换算的酒瓶数;

[03] Recursive Function递归应用的更多相关文章

  1. Recursive - leetcode [递归]

    经验tips: Recursion is the best friend of tree-related problems. 一是只要遇到字符串的子序列或配准问题首先考虑动态规划DP,二是只要遇到需要 ...

  2. T-SQL with as 的用法(转) SQL 下的递归查询 SQL2005(CTE) ,SQL2000(Function 递归)

    摘自: http://blog.csdn.net/bluefoxev/article/details/6779794 ------- SQL2005 方法 一.WITH AS的含义     WITH ...

  3. sql function递归

    alter function Fn_GetUserGroupRelation ( @DHsItemID int ) returns nvarchar(1024) begin declare @Col_ ...

  4. forward reference前向引用,gloal values and local values全局变量和局部变量,recursive function递归函数

    1.全局变量与局部变量练习 1 # -*- coding: UTF-8 -*- 2 def bar(): 3 print('from bar') 4 def foo(): 5 print('from ...

  5. React-router4 第七篇 Recursive Paths 递归路径

    https://reacttraining.com/react-router/web/example/recursive-paths import React from 'react' import ...

  6. Python~recursive function递归函数

    尾递归实现循环 def fact(n): if n==1: return 1 else : return n * fact(n-1) raw_input() 字符而非数字 unsupported op ...

  7. cs224d 自然语言处理作业 problem set3 (一) 实现Recursive Nerual Net Work 递归神经网络

    1.Recursive Nerual Networks能够更好地体现每个词与词之间语法上的联系这里我们选取的损失函数仍然是交叉熵函数 2.整个网络的结构如下图所示: 每个参数的更新时的梯队值如何计算, ...

  8. cs224d 作业 problem set3 (一) 实现Recursive Nerual Net Work 递归神经网络

    1.Recursive Nerual Networks能够更好地体现每个词与词之间语法上的联系这里我们选取的损失函数仍然是交叉熵函数 2.整个网络的结构如下图所示: 每个参数的更新时的梯队值如何计算, ...

  9. learning scala Function Recursive Tail Call

    可以使用scala库,可以从字面上看出是在调用 递归函数: code import scala.util.control.TailCalls._ val arrayDonuts: Array[Stri ...

随机推荐

  1. 每天进步一点点------Xilinx FPGA开发工具 EDK SDK术语

    XPS:Xilinx Platform Studio,平台工作室.用于嵌入式处理器硬件部分的开发. SDK:Software Development Kit,软件开发套件.基于Eclipse平台,支持 ...

  2. UC972开发板,参考实验8,完成定时器触发信号输出实验

    代码 ETIMER0 TGL --> PB2 #include "nuc970.h" #include "sys.h" #include "et ...

  3. 使用SqlDataReader的查询操作

    原创weixin_42430576 发布于2019-01-31 18:49:41 阅读数 762  收藏 展开 using System; using System.Collections.Gener ...

  4. rest framework 序列化之depth遇到用户表外键的尴尬情况

    rest framework 序列化之depth遇到用户表外键的尴尬情况 问题:ModelSerializer序列化使用depth=1直接扩表把用户表所有信息查询出来的情况 class xxxSeri ...

  5. opencv:联通组件扫描

    #include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace st ...

  6. 概率DP lightoj 1265

    题意: 1.两只老虎相遇 就互相残杀 2.老虎与鹿相遇 鹿死 3.老虎与人相遇 人死 4.人与鹿相遇     鹿死 5.鹿与鹿相遇     无果 求人活的概率 解析:如果老虎为0  则人活得概率为1 ...

  7. 题解【POJ2955】Brackets

    Description We give the following inductive definition of a "regular brackets" sequence: t ...

  8. mybatis--一对多关联

    今天来介绍mybatis的一对多关联 (1)首先创建数据库mybatisonetomany,并创建数据库表post和user,并向其中插入一定的数据: create database mybatiso ...

  9. 论STA | POCV/SOCV 对lib 的要求 (4)

    在芯片制造过程中的工艺偏差由global variation 和local variation 两部分组成. 在集成电路设计实现中,global variation 用PVT 跟 RC-corner ...

  10. Python格式化字符串知多少

    字符串格式化相当于字符串模板.也就是说,如果一个字符串有一部分是固定的,而另一部分是动态变化的,那么就可以将固定的部分做成模板,然后那些动态变化的部分使用字符串格式化操作符(%) 替换.如一句问候语: ...