A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 迷途老马 中级黑马   /  2015-10-20 23:14  /  631 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

按递推方法,将n-1个圆盘按要求放在C塔,第n个圆盘放在B塔,现在A塔空。n号圆盘是最大的圆盘,按问题要求我们终于把n号最大的圆盘放在了B塔,这下借助已空的A塔联合BC塔推回来,就可以把n个圆盘按要求放在B塔。


import java.io.BufferedReader;
import java.io.InputStreamReader;

public class Hanoi {
     public static void main(String args[]) throws Exception {
          int n;
       BufferedReader buf =
                new BufferedReader(new InputStreamReader(System.in));
         System.out.print("请输入盘数:");
         n = Integer.parseInt(buf.readLine());
         Hanoi hanoi = new Hanoi();
         hanoi.move(n, 'A', 'B', 'C');
     }

    public void move(int n, char a, char b, char c) {
       if (n == 1)
             System.out.println("盘 " + n + " 由 " + a + " 移至 " + c);
       else {
           move(n - 1, a, c, b);
             System.out.println("盘 " + n + " 由 " + a + " 移至 " + c);
            move(n - 1, b, a, c);
         }
     }
}

4 个回复

正序浏览
个人表示,看代码秒懂。
题目倒是没看懂。。。
回复 使用道具 举报

前辈,你入学了么
回复 使用道具 举报
6666666666666
回复 使用道具 举报
jlq 中级黑马 2015-10-21 00:26:54
沙发
so yyi de si
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马