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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 乔兵 高级黑马   /  2013-10-11 12:34  /  1238 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 乔兵 于 2013-10-11 13:48 编辑


  有一根27厘米的细木杆,在第3厘米、7厘米、11厘米、17厘米、23厘米这五个位置上各有一只蚂蚁。木杆很细,不能同时通过一只蚂蚁。开始时,蚂蚁的头朝左还是朝右是任意的,它们只会朝前走或调头,但不会后退。当任意两只蚂蚁碰头时,两只蚂蚁会同时调头朝反方向走。假设蚂蚁们每秒钟可以走一厘米的距离。编写程序,求所有蚂蚁都离开木杆的最小时间和最大时间。

java实现代码:
  1. public class test_ant
  2. {
  3.     private int[] ants = new int[5];
  4.     // 1:左 2:右
  5.     private int enumDirection[][] = new int[32][5];
  6.     private void initDirection()
  7.     {
  8.         for (int i = 16, column = 0; i > 0; i = i / 2, column++)
  9.         {
  10.             int n = 1;
  11.             for (int j = 0; j < 32; j++)
  12.             {
  13.                 if((j / i) % 2 == 0)
  14.                     enumDirection[j][column] = 1;
  15.                 else
  16.                     enumDirection[j][column] = 2;
  17.             }
  18.         }
  19.     }
  20.     private boolean checkAnts()
  21.     {
  22.         for (int i = 0; i < 5; i++)
  23.         {
  24.             if (ants[i] > 0 && ants[i] < 28)
  25.                 return true;
  26.         }
  27.         return false;
  28.     }
  29.     private void changeDirection(int row, int col)
  30.     {
  31.         if (enumDirection[row][col] == 1)
  32.             enumDirection[row][col] = 2;
  33.         else
  34.             enumDirection[row][col] = 1;
  35.     }
  36.     public void antClimb()
  37.     {
  38.         initDirection();
  39.         for (int n = 0; n < 32; n++)
  40.         {
  41.             int seconds = 0;
  42.             ants[0] = 3;
  43.             ants[1] = 7;
  44.             ants[2] = 11;
  45.             ants[3] = 17;
  46.             ants[4] = 23;
  47.             while (checkAnts())
  48.             {
  49.                 seconds++;
  50.                 for (int i = 0; i < ants.length; i++)
  51.                 {
  52.                     if (i < ants.length - 1)
  53.                     {
  54.                         // 蚂蚁相遇
  55.                         if ((ants[i] == ants[i + 1])
  56.                                         && ((enumDirection[n][i] + enumDirection[n][i + 1]) == 3))
  57.                         {
  58.                             changeDirection(n, i);
  59.                             changeDirection(n, i + 1);
  60.                         }
  61.                     }
  62.                     if (enumDirection[n][i] == 1)
  63.                         ants[i]--;
  64.                     else
  65.                         ants[i]++;
  66.                 }
  67.             }
  68.             for (int j = 0; j < 5; j++)
  69.                 System.out.print(enumDirection[n][j]);
  70.             System.out.println("");
  71.             System.out.println(seconds);
  72.         }
  73.     }
  74.     public static void main(String[] args)
  75.     {
  76.         new test_ant().antClimb();
  77.     }
  78. }
复制代码

其中ants数组保存了5只蚂蚁当前在竿上的位置
enumDirection枚举了所有的32种初始化方向,1代表向左,2代表向右

最短11秒, 最大25秒


运行结果:

11111
23
11112
17
11112
23
11122
11
11112
23
11122
17
11122
23
11222
17
11112
23
11122
21
11122
23
11222
21
11122
23
11222
21
11222
23
12222
21
11112
25
11122
25
11122
25
11222
25
11122
25
11222
25
11222
25
12222
25
11122
25
11222
25
11222
25
12222
25
11222
25
12222
25
12222
25
22222
25

转自blogjava.net/nokiaguy

评分

参与人数 1技术分 +1 收起 理由
杨志 + 1 算法永远是程序设计的灵魂!

查看全部评分

1 个回复

倒序浏览
FFF 金牌黑马 2013-10-11 13:44:41
沙发
这个例子很好,很有启发,学习了!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马