P117 例6-3 设计模拟汉诺塔问题求解过程的算法。汉诺塔问题的描述是:设有3根标号为A,B,C的柱子,在A柱上放着n个盘子,每个上面的盘子都比下面的盘子略小一点,要求把A柱上的盘子全部移到C柱上。

P117 例6-3 设计模拟汉诺塔问题求解过程的算法。汉诺塔问题的描述是:设有3根标号为A,B,C的柱子,在A柱上放着n个盘子,每个上面的盘子都比下面的盘子略小一点,要求把A柱上的盘子全部移到C柱上。移动的规则是:①一次只能移动一个盘子;②移动过程中大盘子不能放在小盘子上面;③在移动过程中,盘子可以放在标号为A,B,C的任意一根柱子上。

#include<stdio.h>

void Towers(int n,char fromPeg,char toPeg,char auxPeg)
{
	if(n==1)
	{
		printf("%s %c %s %c\n","move disk 1 from peg",fromPeg,"to peg",toPeg);
		return;
	}
	
	Towers(n-1,fromPeg,auxPeg,toPeg);
	
	printf("%s %d %s %c %s %c\n","move disk",n,"from peg",fromPeg,"to peg",toPeg);
	
	Towers(n-1,auxPeg,toPeg,fromPeg);
	
}

int main()
{
	Towers(4,'A','C','B');
	return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值