Hanoi问题

教程视频参考:https://www.bilibili.com/video/av12642530/#page=20

问题:

代码如下:

//Hanoi问题
//========================================
#include<iostream>

using namespace std;

void move(char X, char Y)
{
	cout << "move" << X << "to" << Y << endl;
}

void Hanoi(int n, char X, char Y, char Z)
{
	if (n <= 1)
	{
		move(X, Z);
	}
	else
	{
		Hanoi(n - 1, X, Z, Y);
		move(X, Z);
		Hanoi(n - 1, Y, X, Z);
	}
}

void main(void)
{
	int n = 5;
	char X = 'X';
	char Y = 'Y';
	char Z = 'Z';
	Hanoi(n, X, Y, Z);
	while (1);
}

由于一直在做一种重复性操作,所以可以使用递归的方法,分而治之,化成子问题,再递归。

 

posted @ 2017-11-22 11:05  outthinker  阅读(357)  评论(0编辑  收藏  举报