无锡华容道的破解法(华容道解决方法)

hacker|
218

谁知道华容道的破解方法

你的这个问题有前辈已经解答过

华容道解法(1)——横刀立马首先规定一下棋子的名称:

最大的“曹”,横着放的“关”,竖着放的“飞”,最小的“兵”。

横刀立马 81步

兵左1格,飞下,关右,兵下,飞右,兵上1,兵左,飞下,关左,兵上折右,兵上,飞右,兵右折下,关下,二兵左,二飞上,二兵右,关下,兵下折左,二飞左,飞下,曹右,

飞右,二兵上,飞左,飞下,曹左,

飞上,飞右,兵上,兵左折上,关右,二飞下,兵左,曹下,

兵右,兵上折右,兵上,飞上,飞左,兵左折下,曹下,

兵下折左,飞左,飞上,曹右,

兵下1,上兵下1,兵右,二飞上,兵左,兵下,曹左,

飞下,飞右,二兵右,飞右,飞上,曹左,

二兵下,飞左,飞上,兵右折上,关上,二兵右,曹下,

二兵左,关上,兵上折右,曹右!

华容道解法(2)——层层设防

层层设防 102步

关左、兵下折左、兵下、飞下、曹右、

飞右、二兵上、二关左、飞左、兵上、兵右折上、关右、二关下、兵下折右、兵下、飞左、曹左、

二兵上、飞右、关右、兵下、兵左、关上、兵右、关上、关左、飞下、兵下、二关右、兵右、飞下、曹左、

兵左折上、关上、飞上、二兵右、关右、飞下、曹下、

二兵左、关上、兵上折右、曹右、

兵下、兵左折下、关左、兵上折左、飞上、兵上、二关右、飞右、二兵下、曹左、

兵左、兵下、飞下、关右、曹上、

二兵上、飞上、关左、关下、飞下、兵右、兵上、飞右、兵右折下、曹下、

关左、二兵上、二飞上、关上、关右、二兵下、曹下、

关下、二兵左、二飞上、二关上、二兵右、曹下、

关左、兵上折右、曹右!

华容道最快解法口诀

1、首先,摆好华容道横刀立马。

2、左底角兵右,右底角兵左,张下,黄下,关右,中左兵上左,底中兵上二。

3、黄右,中边兵下二,中兵左下,关左二,中兵上右,中边兵上二,黄右。

4、中边兵右下,关下,中兵左二,中边兵左二。黄上,张上,底中兵右二,右底角兵右二。

5、关下,中兵下左,黄左,张左,赵下二。

6、曹右,马右,中上边兵上二,中下边兵上二,黄左,马下二,曹左。

7、赵上二,张右,下边兵上二,右底角兵左上,关右二。

8、黄下,马下,中兵左二,曹下,顶角兵右二,中上边兵上右,中下边兵上二,黄上二,马左,中兵左下,曹下。

9、中右兵下左,赵左,张上二,曹右。

10、中兵下二,顶边兵下一,顶角兵右,黄上。

11、马上,底中兵左,中兵下,曹左。

12、张下二,赵右,二兵右,黄右,马上二,曹左,中兵下二,顶中边兵下二,赵左,张上二,中下兵右上。

13、关上,底中兵右二,右底角兵右二,曹下,中兵左二,中边兵左二,关上,底中兵上右,曹右。(完成)

华容道的解法步骤

华容道"近在咫尺"通关步骤(117步)

张下,关下,卒下右,上卒下二,赵左,中卒上二,右卒左上,右卒左二,曹上,张右,关下,右卒下左,曹左,黄下,马右,下卒右上,曹上,卒右二,卒下左,赵下,卒左下,卒左二,曹上,左卒上右,赵右,二卒下二,曹左,马左,黄上,下卒右上,张上,关右,赵下,上卒右,中卒上,赵左,上卒下二,右二卒左,张左,黄下,马右,曹右,卒上二,卒左上,卒左二,张上,卒上右,关左,黄下,张右,左卒右下,张左,黄上,关右,卒下,中卒左,黄左,马下,曹右,下卒右上,张上,赵上,二卒上,关左,黄下,马下,曹下,上二卒右二,张上,中卒上左,曹左,马上,黄右,卒右下,曹下,上卒下左,卒左下,张右,左卒上右,赵上,曹左,上卒下二,马左,黄上,中卒右下,马下,中卒右,卒下,张左,黄上,马右,曹右,赵下,张左,二卒左,黄左,马上,曹右,上卒下一,上卒右,赵上,关上,下二卒左二,曹下,马下,黄下,张右,赵上,二卒上,关上,右卒上左,曹左 华容道已经被研究过多年,也总结了许多关口的走法,为让各位喜欢华容道的朋友少走弯路,我把一些走法整理出来,与大家分享。

下面的走法沿用L.E.Hordern的记录方法,即在多数情况下只要指明走哪一个棋子就够了,只有少数情况下才指明如何走。这时用以下符号来表示。L向左;R向右;U向上;D向下;!只走一格;#必须拐弯(指最小棋子)。没有这些符号时,表示直走,到头为止(一格或两格)。棋子编号见图1。当然,这只是指出了如何过关,大家也不必死记硬背这些步骤,关键要从此研究出过关的必要条件,而达到通关的目的。

(1) 横竖皆将

6 4 5 7 # 9 6 8 3 5 7 9 L 2 A 7 5 1 7 L A 2 4 5 9 L 4 5 8#3 1 9 L 4 5 8#3 1 9 L 4 5# 2A 9 # 4 1 3 6 8 5 2 A 9 7 4 3 5 8 6 D 3 A 9 1 7 4 3 1 2 2 6R 5# 8# A 9 1 7 4 3 1 A 9 1 7 2 6 8 5 A 9 3 4 2 6 5 # A

(2)守口如瓶之一

5 7L 2 A 1 3 6 4 1 A 2 7# 9 8 4 1 6 #4 1 6 5 #7 9 5 6 #1 4 7 # 9 5#2 A 7 #9 4 1 8 6 D 5 2 A 7 3 9 1 5 6 7 1 4 D 1 A 7 1 3 9 1 4 2 8 R 5 #6#A 7 1 3 9 1 4 A 8 3 2 8 6 5 A 7 1 9 2 8 5#A

(3)守口如瓶之二

7#9 8 6 #3 1 A 2 4 7 R 2 A 1 3 6 #8 9 7#4 A 5 6 #8 9 7 # 8 9 3 6# 51 6 U 5 1 A 4 81 2U 8 1 1 7 9 3 5 2#8 7 # 4 A 2#8 5 3 9 1 7 4 A 2 6 8 3 7 1 9 5 D 3 9 2 1 6 8 3 5 4 9 R 1# 7# A 2 1 6 8 3 5 A 2 1 6 4 A 7 1 A 2 3 8 4 9 1#A

(4)层层设防之二

9 L8#4 2 A 1 3 5 2 4 8 9 6 7 2 5 3 1 L,A 4 5 2 7 6 9 8 2 7 6 # 7 8# 7 9 3 6 # 5 8 #4 A 6# 5 3 8 9 2 4 A 6 1 5 8# A 6 1 1 5 8 3 4 7 2U 9 7 2 A 6 1# 4 A 6 3 2 6# 7 9 A 1#3 2 8 5 3 1 A 9 7 1# A 4 3 2 # A 1 6# 8 A 1 4 3 1# 4 3 9 7 8 6 D A 6 2 1 4 3 9 7 6 8 A 9 7 8 #A

(5)Top secret

7 5 3 2 1 4 6 7 L A 1#4 6 7 1 1 3 5 9 8 A 1 4 2 5 3# 4 7 R 6 2 4 1 A 8 9 3 D 5 1 4 2 7 U 6 U A 1 3 9 8 3 D 1 D A 7D 6D 2 5 4 9 8 3 1 A 9 8 1#A

(6)三军联防

6 7 4 3 7# 3 4 2 1 A 7 5 8 4 6 9# 6 4 8 3 9 L 2 1 A 5# 3 8 9 U 4 6 2 1 A5 7

3 9# A 1 2 4 6 8 9 A 1 2 4 6 9# A 3 7 5 1 2 4 6 9 8 A 4 6 8#A

(7)堵塞要道

5 9 6 7 4#2 A 3 #7 5 6 9 8 4 2 D A 3 1 7 5 6 9 8 4 2 D A 1 3 D 7 5 6 9 8 4 2 A 9 8 2#A

(8)水泄不通

9 7 6 8 9 U 7 6 5 4 8 9 U 5 4 9 A 1 3# 8 A 1 2 9 1# 4 5 A 3# 21# 4 5 6 7 A 5 4 1# 2 3 #5 4 2 1 9 D 3 8 5 4 A 7 6 1# 9 3 8#5 4 A 1 9 6 7 1 9 D A 4 5 2 8 3 U 6 7 9 1 A 6 7 1#A

(9)四路进兵(原文 67步,11 66步)

A 4 3 #2 A 4 3 #1 5 2 #7 6 A 3 #1 2 #7 6 9 8 A 6 7 2 0#1 3 #6 7 1 2 5 D 3 4 6 7 A 8 9 2# 5 3 4# 6 7 A 2 5 9 8 2 5 D A 7 6 1 4 3 U 9 8 5 2 A 9 8 2# A

华容道问题用计算机求解,一般采用广度搜索的方法,其原理很简单,就是把下一步可能有的走法全部算出来,比如第一步有五种走法,将这五种走法的下一步走法分别算出来,可能会有三十步,在继续将这三十步走法的下一步走法分别算出来,可能会更多,以此类推,直到达到目标状态(曹操在出口位置)为止。

在解华容道的问题上,我觉得有两个问题比较棘手。

其一、算法的效率。

其二、获得最优解法。

我是这样解决的:

1、 要提高算法的效率,首先要知道算法的瓶颈在什么地方,在得出每一个状态(走完一步各个棋子的位置)都要和前面的状态进行比较,以保证不重复,随着步数的增多,状态数会大幅度增加,这是,和前面的状态比较这一过程成了整个算法的效率。解决的办法,从两个地方着手,其一,增加每一步比较的速度。在程序中,用5*4的数组表示一个状态,这样,每一次比较要比较二十个数,因为数组中每个数定义从0-7,用三个二进制位可以表示,3*20=60位,用一个64位数就可以表示(有的资料说用四个字节就可以,我实在想不出来),这样每次比较一个64位数就可以了。其二、减少比较的状态,这是提高效率的关键。比较的时候不要和前面所有的状态都进行比较,只要和前两步的所有状态进行比较就可以了。经过以上的优化,在解横刀立马时,大约需要一,两秒钟就可以了,(我的机器,赛扬1.1OC1.46)。

2、 获得最优解法,比如横刀立马是81步,这里的一步指移动一个棋子,可以把一个卒子向一个方向移动两格,或者卒子拐弯移动两格,或者一个将向一个方向移动两格(横将横着移,竖将竖着移)都是一步。获得最优解法的关键是把下一步可能有的走法全部算出来,不能遗漏。我是根据空格来算走法的的,分三种情况:

① 、卒子拐弯移动,如果有连着两个空格(横向的),则如果在它的上面或下面(有四个位置)有卒子的话,那么可以拐弯移动,有四种走法。如果两个空格是竖向的,那么,空格的左右如果有卒子,也可以拐弯移动,也有四种走法。

②、向一个方向移动两格,这里可能出现的情况有:卒子向一个方向移动两格,横将横着移两格,竖将竖着移两格

③、考虑向一个方向移动一格的情况,这里情况很多,我不一一列举了。

以上的算法很麻烦,很大一部分程序用来写这个了,如果大家有更简单的,可以告诉我,但一个原则,必须把所有的走法全部考虑。 我知道的只有这些了,希望采纳。

数字华容道游戏5×5的,我差最后3个排不了,哪位会的教教我

首先,前三排,每排前三个数都按顺序从左往右放,后两个数要调整一下从右往左放。最后两排是关键,个人建议先把左侧16、17上下放。

然后,再把18、19、20放在右侧排列好,剩下只要想办法把24放到18下面,基本就解决难题了。再将23、22、21依次按顺序放在24左侧,基本就大功告成。

先对第一排,将1、2、3一个个移到目标位置,这一步不需要什么技巧,只管将三个数字-个一个移就行,其它数字不用管。在移数字4时先移到目标位下面, 将4同排左边的两个数字往右移1格,再将第一排的1、2、3三个数字整体逆时针往左退一格。

这时就可以把4移到右上角目标位,移好后将4左边的无关数字移走,把1、2、3整体顺时针往右回倒一格,这样第一排就对好了。第二排与第一排同。

华容道的解法的思路是什么?

华容道最常见的有七种排列方式。主要是要让关羽给曹操让条道路,也就是让关羽带着那四个小卒跑到曹操的上面或者下面去,这样曹操就可以通行了。更多的是需要你自己研究。

记得采纳啊

4条大神的评论

  • avatar
    访客 2022-09-21 上午 03:41:48

    兵右,关下,兵下折左,二飞左,飞下,曹右,飞右,二兵上,飞左,飞下,曹左,飞上,飞右,兵上,兵左折上,关右,二飞下,兵左,曹下,兵右,兵上折右,兵上,飞上,飞左,兵左折下,曹下,兵下折左,飞左,飞上,曹右,兵下1,上兵下1,兵右,二飞上,兵左,兵下,曹左,飞下,飞右,二兵右,飞右,飞上,曹左,

  • avatar
    访客 2022-09-21 上午 04:19:00

    6 8 A 9 7 8 #A (5)Top secret 7 5 3 2 1 4 6 7 L A 1#4 6 7 1 1 3 5 9 8 A 1 4 2 5 3# 4 7 R 6 2 4 1 A 8 9 3 D 5 1 4 2 7 U 6

  • avatar
    访客 2022-09-20 下午 09:37:27

    ,再将第一排的1、2、3三个数字整体逆时针往左退一格。这时就可以把4移到右上角目标位,移好后将4左边的无关数字移走,把1、2、3整体顺时针往右回倒一格,这样第一排就对好了。第二排与第一排同。华容道的解法的思路是什么?华容道最常见的有七种排列方式。主要是要让关

  • avatar
    访客 2022-09-21 上午 01:49:48

    兵下1,上兵下1,兵右,二飞上,兵左,兵下,曹左,飞下,飞右,二兵右,飞右,飞上,曹左,二兵下,飞左,飞上,兵右折上,关上,二兵右,曹下,二兵左,关上,兵上折右,曹右!华容道解法(2)——层层设防层层设防 102步关左、兵下折左、兵下、飞下、曹右、飞

发表评论