递归。

是的,差不多就是这种感觉。上面就是类似递归的显示表现。

2017 10 24更新:

递归这个问题放了很久。也没有写。大概是自己还没有好好理解吧。

在这里写下自己理解的全部。

一 何为递归。

字面意义,分开看。 有传递。有回归。或者归还。

浅显的理解就是调用自己。

那么递归可以调用自己,肯定是有一些约束的条件。 不然就会无限次的调用自己。这个很好理解吧? 

说一个小示例来讲解一下何为递归。

一个房子里面有一个男人在玩着一个房子模型,房子模型里面还有一个房子,房子里面有一个男人,男人在玩着一个房子模型,房子模型里面有一个男人,男人在玩着一个房子模型....

从前有一个座山,山上有一座庙,庙里有个老和尚,老和尚再给小和尚讲故事,故事是从前有一个座山,山上有一座庙,庙里有一个老和尚,老和尚再给小和尚讲故事,故事是从前有一座山...

这就是递归了。

OK,讲了这么多,那么如何写呢?

其实写递归还好,最重要的是理解递归。

例子:

  1. int fu(int n)
  2. {
  3. if(n==)
  4. return ; //递归出口
  5. else
  6. return n*fu(n-); //递归
  7.  
  8. }

二: 递归出口

刚才讲递归是要约束的,那么递归的约束就是递归出口。

递归出口是什么呢?

你想想啊,刚才我举了两个例子,房子和老和尚。如果没有出口是不是就无限递归了。

我们使用递归,不是为了无限递归了。没什么用了啊!

所以要有一个出口,也就是递归的限制。

三 递归使用

递归的本质和循环差不多的。递归能干的事情,循环也能干。

那么为什么递归还要存在呢,因为短小精悍。

OK,那么什么情况下会用到递归呢? 你需要写一个函数,函数的内容都很单一(就是处理一个事物),能用循环解决的。这些都可以用递归来解决。

那么示例1:

阶乘

  1. int fu(int n)
  2. {
  3. if(n==)
  4. return ; //递归出口
  5. else
  6. return n*fu(n-); //递归
  7.  
  8. }

嗯,这就是一个阶乘递归。

阶乘是什么呢?

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语言_递归的更多相关文章

  1. 温故而知新_C语言_前缀++(--)和后缀++(--)

    前缀++(--)和后缀++(++)是有区别的. 再单独使用的时候是没有区别的,都是自身递增或者递减1. 但是综合使用起来会一样吗? 下面的例子都是++,替换成--也是一样,道理都是一样的. 请先看下面 ...

  2. 选择排序_C语言_数组

    选择排序_C语言_数组 #include <stdio.h> void select_sort(int *); int main(int argc, const char * argv[] ...

  3. 插入排序_C语言_数组

    插入排序_C语言_数组 #include <stdio.h> void insertSort(int *); int main(int argc, const char * argv[]) ...

  4. 快速排序_C语言_数组

    快速排序_C语言_数组 #include <stdio.h> void quickSort(int *, int, int); int searchPos(int *, int, int) ...

  5. 冒泡排序_C语言_数组

    冒泡排序_C语言_数组 #include <stdio.h> //冒泡排序 小->大 void sort(int * pArray, int len); int main(int a ...

  6. 温故而知新_C语言_define_宏

                                                                                             define defi ...

  7. 数据结构_C语言_二叉树先序、中序、后序遍历

    # include <stdio.h> # include <stdlib.h> typedef struct BiTreeNode { char data; struct B ...

  8. 数据结构_C语言_单链表

    # include <stdio.h> # include <stdbool.h> # include <malloc.h> typedef int DataTyp ...

  9. 【书籍下载链接】_1_第一轮_C语言书籍

    各位朋友,如果您觉得下载的电子书,看的还可以,请购买纸质版的图书,如果您觉得 您下载的书,不值得一看请在下载后直接删除. Windows汇编:http://dl.vmall.com/c0jk1v970 ...

随机推荐

  1. 0. LeetCode 开篇

    LeetCode 开篇 很久以前(也许是几天之前,记忆力没那么好),听朋友说过,但是没怎么重视,最近发现自己基础打的不牢(会是会,但是说不出来,说不明白),故借此机会理一理知识点,并复习,巩固相关知识 ...

  2. 使用 acl 库针对 C++ 对象进行序列化及反序列编程

    在开发网络应用程序时,各个模块之间的数据通信可谓是家常便饭,为了应对这些数据通信时数据交换的要求,程序员发明了各种数据格式:采用二进制数据结构(早期 C 程序员).采用 XML.采用SOAP(坑人的设 ...

  3. 愿天下有情人都是失散多年的兄妹(bfs)

    L2-016. 愿天下有情人都是失散多年的兄妹 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 呵呵.大家都知道五服以内不得通婚 ...

  4. 版本管理 word 文档比较

    1.因为公司还在用SVN, 2.而且 还在用word 写文档, 3.而且 commit log 基本不写, 所以导致,想了解word文档 改动, 很浪费时间!!!! 所以想 快速了解word 改动, ...

  5. 使用Asset Pipeline管理rails生产环境静态资源实现步骤

    1.    修改项目中指向静态资源文件的链接 a)     访问静态资源文件 <%= stylesheet_link_tag "application", media: &q ...

  6. SQL基础(1)

    1.SQL简介 (1)什么是SQL? SQL指结构化查询语言 SQL使我们有能力访问数据库 SQL是一种 ANSI 的标准计算机语言 (2)SQL 能做什么? SQL面向数据库执行查询 SQL可从数据 ...

  7. PDM/CDM中进行搜索

    Option   Explicit ValidationMode   =   True InteractiveMode =   im_Batch Dim   mdl   '当前model '获取当前活 ...

  8. 01-16委托Func

    在类中编写方法: 在主函数中调用函数: 效果图:

  9. iter创建一个可以被迭代的对象

    #!/usr/bin/env python obj = iter([11,22,33,44]) #iter 创建一个可以被迭代的对象 print(obj) r1 = next(obj) print(r ...

  10. 第4章_Java仿微信全栈高性能后台+移动客户端

    基于web端使用netty和websocket来做一个简单的聊天的小练习.实时通信有三种方式:Ajax轮询.Long pull.websocket,现在很多的业务场景,比方说聊天室.或者手机端onli ...