Java教程

汉诺塔程序详解

本文主要是介绍汉诺塔程序详解,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

把A柱的碟盘移动到C柱上面

#include <stdio.h>
#include <stdlib.h>

void hanoi(int n, char a, char b, char c);

void hanoi(int n, char a, char b, char c)
{
	if(n == 1) {
	printf("%d:%c to %c, ", n, a, c);
	}
	else{
		hanoi(n-1, a, c, b);                      //把A上n-1个盘子通过借助辅助塔(C塔)移到了B上
		printf("%d:%c to %c, ", n, a, c);
		hanoi(n-1, b, a, c);                      //把B上n-1个盘子通过借助辅助塔(A塔)移到了C上
	}
}

int main(void)
{
	hanoi(3, 'A', 'B', 'C');
	return EXIT_SUCCESS;
}

用的是递归方法

这篇关于汉诺塔程序详解的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!