温故而知新_C语言_递归
递归。

是的,差不多就是这种感觉。上面就是类似递归的显示表现。
2017 10 24更新:
递归这个问题放了很久。也没有写。大概是自己还没有好好理解吧。
在这里写下自己理解的全部。
一 何为递归。
字面意义,分开看。 有传递。有回归。或者归还。
浅显的理解就是调用自己。
那么递归可以调用自己,肯定是有一些约束的条件。 不然就会无限次的调用自己。这个很好理解吧?
说一个小示例来讲解一下何为递归。
一个房子里面有一个男人在玩着一个房子模型,房子模型里面还有一个房子,房子里面有一个男人,男人在玩着一个房子模型,房子模型里面有一个男人,男人在玩着一个房子模型....
从前有一个座山,山上有一座庙,庙里有个老和尚,老和尚再给小和尚讲故事,故事是从前有一个座山,山上有一座庙,庙里有一个老和尚,老和尚再给小和尚讲故事,故事是从前有一座山...
这就是递归了。
OK,讲了这么多,那么如何写呢?
其实写递归还好,最重要的是理解递归。
例子:
int fu(int n)
{
if(n==)
return ; //递归出口
else
return n*fu(n-); //递归 }
二: 递归出口
刚才讲递归是要约束的,那么递归的约束就是递归出口。
递归出口是什么呢?
你想想啊,刚才我举了两个例子,房子和老和尚。如果没有出口是不是就无限递归了。
我们使用递归,不是为了无限递归了。没什么用了啊!
所以要有一个出口,也就是递归的限制。
三 递归使用
递归的本质和循环差不多的。递归能干的事情,循环也能干。
那么为什么递归还要存在呢,因为短小精悍。
OK,那么什么情况下会用到递归呢? 你需要写一个函数,函数的内容都很单一(就是处理一个事物),能用循环解决的。这些都可以用递归来解决。
那么示例1:
阶乘
int fu(int n)
{
if(n==)
return ; //递归出口
else
return n*fu(n-); //递归 }
嗯,这就是一个阶乘递归。
阶乘是什么呢?
1! =1*1
2!=2*1
3!=3*2*1
4!=4*3*2*1
5!=5*4*3*2*1
就是这个数乘上这个数以前所有的数。
那么如何理解这个阶乘算法呢?
比如说求5的阶乘。
5的阶乘是不是5*4的阶乘
4的阶乘是不是4*3的阶乘
3的阶乘是不是3*2的阶乘
2的阶乘是不2*1的阶乘
1的阶乘是不是1
看见没,求5的阶乘你必须先回到到1的阶乘,一步一步向上计算才能算到5的阶乘。这一个过程就是递归。
递归的过程是:递到1,归回5.
让我们看一下流程图。

上面的图不太标准,如果有在学习算法的话,理解一下栈,可以对递归的理解有一定的帮助。
四 递归的理解。
递归呢,很好用,但是呢也有一定的缺陷,比如时间的复杂度啊,很浪费空间啊。
但是在代码上确实很简短。
说起来还是要理解你要处理的事物,对这个事物的算法有一定要深度理解。
要能推算出能够递归的算法。 就如比说上面的乘阶。 很明显就能看出来是个递归的算法。
符合递归的算法是什么?
说实话 我也不是会很多。但是呢 肯定有一个特点。
可以推算到最底部,或者最开始的部分。
然后呢在沿着向上可以算出最顶部的部分。
我理解的递归就是如此了。
温故而知新_C语言_递归的更多相关文章
- 温故而知新_C语言_前缀++(--)和后缀++(--)
前缀++(--)和后缀++(++)是有区别的. 再单独使用的时候是没有区别的,都是自身递增或者递减1. 但是综合使用起来会一样吗? 下面的例子都是++,替换成--也是一样,道理都是一样的. 请先看下面 ...
- 选择排序_C语言_数组
选择排序_C语言_数组 #include <stdio.h> void select_sort(int *); int main(int argc, const char * argv[] ...
- 插入排序_C语言_数组
插入排序_C语言_数组 #include <stdio.h> void insertSort(int *); int main(int argc, const char * argv[]) ...
- 快速排序_C语言_数组
快速排序_C语言_数组 #include <stdio.h> void quickSort(int *, int, int); int searchPos(int *, int, int) ...
- 冒泡排序_C语言_数组
冒泡排序_C语言_数组 #include <stdio.h> //冒泡排序 小->大 void sort(int * pArray, int len); int main(int a ...
- 温故而知新_C语言_define_宏
define defi ...
- 数据结构_C语言_二叉树先序、中序、后序遍历
# include <stdio.h> # include <stdlib.h> typedef struct BiTreeNode { char data; struct B ...
- 数据结构_C语言_单链表
# include <stdio.h> # include <stdbool.h> # include <malloc.h> typedef int DataTyp ...
- 【书籍下载链接】_1_第一轮_C语言书籍
各位朋友,如果您觉得下载的电子书,看的还可以,请购买纸质版的图书,如果您觉得 您下载的书,不值得一看请在下载后直接删除. Windows汇编:http://dl.vmall.com/c0jk1v970 ...
随机推荐
- 通过maven的jar包库找到对应的jar包。
查找连接: http://search.maven.org/ 查找实例 http://search.maven.org/#search|ga|1|a%3A%22log4j%22
- [C++] 动态规划之矩阵连乘、最长公共子序列、最大子段和、最长单调递增子序列、0-1背包
一.动态规划的基本思想 动态规划算法通常用于求解具有某种最优性质的问题.在这类问题中,可能会有许多可行解.每一个解都对应于一个值,我们希望找到具有最优值的解. 将待求解问题分解成若干个子问题,先求解子 ...
- [转载]网络虚拟化中的 offload 技术:LSO/LRO、GSO/GRO、TSO/UFO、VXLAN
offload 现在,越来越多的网卡设备支持 offload 特性,来提升网络收/发性能.offload 是将本来该操作系统进行的一些数据包处理(如分片.重组等)放到网卡硬件中去做,降低系统 CPU ...
- java代码流类
总结:读取到的是字节型转换成字符串. package com.c2; import java.io.*; public class tkrp { public static void main(Str ...
- asp.netcore di 实现批量接口注入
废话少说,先上代码 public static Dictionary<Type, Type[]> GetImpleAndInterfaces(string assemblyName,str ...
- Java 中的关键字和保留字
关键字: Java 语言中已经事先定义好了的,有着特殊含义和用途 访问控制 类.方法和变量修饰符 程序控制 异常处理 包相关 基本类型 变量引用 public abstract break try i ...
- PDM生成数据库-0设置表名和字段名中不带双引号
如果PDM直接导出脚本的话,所有的表和字段都会被加上双引号,非常不方便,去除双引号的办法: Database->Edit Current DBMS在弹出窗体中第一项General中找到 Scri ...
- 2014.2.23 datagridview显示图片的方法
DataTable dt = new DataTable(); dt.Columns.Add("", typeof(byte[])); dt.Rows.Add(File.ReadA ...
- oracle 远程tns配置
BYRUIY = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = rui-oracle11g)(PORT = )) (CONNECT_DATA = ...
- 10-23C#基础--结构体
结构体: 1.定义:封装小型相关变量组,里面可以放一系列的变量: 就是一个变量组,将一组变量放在一起,结构体一般定义在Main函数上面,位于Class下面,作为一个类:一般情况Struct定义在Mai ...