1223: 输出汉诺塔问题的盘子移动步骤(Java)

80 篇文章 18 订阅

一、题目

http://acm.wust.edu.cn/problem.php?id=1223&soj=0

二、代码

import java.util.*;

public class Main {

	Scanner in = new Scanner(System.in);
	int step, n;	// step移动的步数,n盘子个数

	/**
	 * 构造方法
	 */
	public Main() {
		while(in.hasNext()){
			// 每次都重置为第一步
			step = 1;
			// 输入盘子个数
			n = in.nextInt();
			// 将n个盘子从A柱子移动到C柱子
			hanoi(n, 'A', 'B', 'C');
			// 每组数据空一行
			System.out.println();
		}
	}

	/**
	 * @param n 盘子个数
	 * @param A 当前状态的第一根柱子
	 * @param B 当前状态的第二根柱子
	 * @param C 当前状态的第三根柱子
	 */
	public void hanoi(int n, char A, char B, char C) {
		// 最后一个盘子直接从A柱子移动到C柱子
		if(1 == n) {
			move(A, C);
		} else {
			// 将上面n-1个盘子从A柱子移动到B柱子
			hanoi(n - 1, A, C, B);
			// 将最下面的盘子从A柱子移动到C柱子
			move(A, C);
			// 将B柱子上的n-1个盘子移动到C柱子
			hanoi(n - 1, B, A, C);
		}
	}

	/**
	 * 将盘子从x柱子移动到y柱子
	 * @param x 盘子的源柱子
	 * @param y 盘子的目的柱子
	 */
	public void move(char x, char y) {
		System.out.println("Case #" + step + ": from " + x 
			+ " to " + y + ".");
		step++;	// 步数加1
	}

	public static void main(String[] args) {
		new Main();
	}

}

三、截图

1223截图

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值