摘要:本文主要向大家介绍了C/C++知识点之数据结构算法C语言实现(十)--- 3.3栈与递归的实现,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
本文主要向大家介绍了C/C++知识点之数据结构算法C语言实现(十)--- 3.3栈与递归的实现,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
一.简介 汉诺塔问题是递归的一个典型例子,而且书上的讲解很详细,对理解C语言函数及函数传参的工作机制很有帮助,值得一看。而且,递归在我看来和分治、DP、贪心等一样是十分优美的思想,值得学习!!!
二.CPP文件
1 //3_3.cpp
2 /**
3 author:zhaoyu
4 email:zhaoyu1995.com@gmail.com
5 date:2016-6-8
6 note:realize my textbook <<数据结构(c语言版)>>
7 */
8 //Page 54
9 #include
10 int cnt = 0;
11 void move(char a, int n, char b)
12 {
13 printf("%i\tmove disk %d from %c to %c\n", ++cnt, n, a, b);
14 }
15 void hanoi(int n, char x, char y, char z)
16 {
17 if (1 == n)
18 {
19 move(x, 1, z);
20 }
21 else
22 {
23 hanoi(n-1, x, z, y);
24 move(x, n, z);
25 hanoi(n-1, y, x, z);
26 }
27 }
28 int main(int argc, char const *argv[])
29 {
30 int n;
31 scanf("%d", &n);
32 hanoi(n, ‘X‘, ‘Y‘, ‘Z‘);
33 return 0;
34 }
3_3.cpp
三.测试
三个:
五个:
容易看出,移动 n 个,需要 2^n - 1次。
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标编程语言C/C+频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号