简单递归问题
来源:互联网 发布:茶叶网络推广 编辑:程序博客网 时间:2024/04/30 08:12
递归(recursion):程序调用自身的编程技巧。
递归满足2个条件:
1)有反复执行的过程(调用自身)
2)有跳出反复执行过程的条件(递归出口)
递归例子:
(1)阶乘
n! = n * (n-1) * (n-2) * ...* 1(n>0)
//阶乘int recursive(int i){int sum = 0;if (0 == i)return (1);elsesum = i * recursive(i-1);return sum;}
(2)汉诺塔问题
//汉诺塔private function hanoi(n:int,p1:int,p2:int,p3:int):void{
<span style="white-space:pre"></span>if(n==1){<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(240, 240, 240);"> </span>
<pre name="code" class="cpp" style="margin-top: 0px; margin-bottom: 0px; white-space: pre-wrap; word-wrap: break-word; color: rgb(75, 75, 75); font-size: 13px; line-height: 19.5px; background-color: rgb(255, 255, 255);"> trace(p1+"====>"+p3);
<span style="white-space:pre"></span>}else{
<span style="white-space:pre"></span> hanoi(n-1,p1,p3,p2);//把A上n-1个盘子借助C移动到B
<span style="white-space:pre"></span> trace(p1+"====>"+p3);//把A上最后的大盘子移动到C
<pre name="code" class="cpp" style="margin-top: 0px; margin-bottom: 0px; white-space: pre-wrap; word-wrap: break-word; color: rgb(75, 75, 75); font-size: 13px; line-height: 19.5px; background-color: rgb(255, 255, 255);"><span style="white-space:pre"></span> hanoi(n-1,p2,p1,p3);//把B上n-1个盘子借助A移动到C,玩活儿!!!
<span style="white-space:pre"></span>}
}
(3)全排列
从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。
如1,2,3三个元素的全排列为:
1,2,3
1,3,2
2,1,3
2,3,1
3,1,2
3,2,1
//全排列inline void Swap(int &a,int &b){int temp=a;a=b;b=temp;}void Perm(int list[],int k,int m){if (k == m-1) {for(int i=0;i<m;i++){printf("%d",list[i]);}printf("n");}else{for(int i=k;i<m;i++){Swap(list[k],list[i]); Perm(list,k+1,m);Swap(list[k],list[i]); }}}
(4)斐波那契数列
斐波纳契数列,又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……
这个数列从第三项开始,每一项都等于前两项之和。
有趣的兔子问题:
一般而言,兔子在出生两个月后,就有繁殖能力,一对兔子每个月能生出一对小兔子来。如果所有兔子都不死,那么一年以后可以繁殖多少对兔子?
分析如下:
第一个月小兔子没有繁殖能力,所以还是一对;
两个月后,生下一对小兔子,总数共有两对;
三个月以后,老兔子又生下一对,因为小兔子还没有繁殖能力,总数共是三对;
……
依次类推可以列出下表:
//斐波那契
long Fib(int n)
{
if (n == 0)
return 0;
if (n == 1)
return 1;
if (n > 1)
return Fib(n-1) + Fib(n-2);
}
0 0
- 简单递归问题
- java 简单递归问题
- 简单递归问题
- 简单背包问题-递归非递归实现
- 一个简单的递归问题
- 递归—简单背包问题
- 杭电简单递归问题
- 简单背包问题递归方法
- 简单的背包问题(非递归和递归)
- 简单背包问题的递归与非递归实现
- 简单的背包问题--java递归实现
- 简单的递归求解乘方问题
- C语言简单函数递归调用问题
- 简单递归—Hanoi(汉诺塔问题)
- 【LeetCode】三道简单的递归问题
- p1054 简单背包问题的递归解法
- OpenJudge 简单的整数划分问题(递归)
- 简单递归问题——烤鸡
- SGU 326. Perspective (最大流)
- 小米如何在社会化媒体上引爆口碑?
- 1176. Two Ends(搜索破解此题)
- LeetCode | Largest Rectangle in Histogram(直方图围城的最大矩形面积)
- 常用的八个CMD命令
- 简单递归问题
- 【c++】计时函数
- 关于启动mysql服务1067错误
- 《编程珠玑(第2版)》笔记——将一个n元一维向量向左旋转i个位置(第2章)
- Android平台下驱动的开发及测试框架概述(二)
- toj 2857. Digit Sorting
- 基于SDL的SDL_mixer库的音乐播放器
- error: ‘for’ loop initial declarations are only allowed in
- hdu-1261