关于本系列贴主题的说明。
8 z# q2 m) X" X& k* @! U; s C 写这个系列的帖子主旨在于深入探讨AVG中某些具有代表性的迷题,讨论研究其中的解题思路以及普遍方法,虽然内容当中肯定会引用特定的迷题做例子并详细解说,但实际上介绍的解题方法却并没有特别针对某一个游戏的某一个迷题而言,算是攻略好像也不太合适。思前想后决定放在“原创评论”这边,姑且算是一种“对某些类型迷题”的评论吧,希望没有违背本版的宗旨。
$ `, C& m3 N0 z& M% m, v* w9 O8 P9 j
& O1 m% K( R( i3 G" D: `
, \3 W( ~2 _+ K( Z1 U& h 9 f3 ^; R+ B# X# |" U1 k
与攻略还有论坛的解答帖子不同,我们在这里要深入探讨一种迷题的“一般解法”,请注意:“一般解法”是一种能让你成功破解任何一个这类迷题的办法,但却不一定是最快捷办法(这是一把万能钥匙,但需要耐心,呵呵~只求通关的朋友请飘过吧!)。
3 m' q. M. v6 e$ X9 P5 X# _
* e; {0 {: E4 c% P( @& _+ G
4 Q7 P* \1 k3 h( D( a4 g2 T# [
* z! w" q& g! I 在论坛的破箱人迷题统计中,这个是令大家最头疼的迷题了,就让我们从这个最大难题开始我们的解迷之旅吧~ / P/ U4 s: `, J1 t7 f1 e5 }) s
* [) O2 t! z- b6 M- ?8 m8 L5 R, {8 [. i1 [
两个基本变换
# S5 W7 |/ {4 O 毛主席说“克思主义的道理千头万绪,归根结底就是一句话‘造反有理’!”,所以既然要找出一般解法,则必须通过归纳,把这个千变万化的拼图迷题简化一下。这个拼图迷题的变化确实很简单,只有一种(下图): 7 ^3 t" O9 [' |) j4 J; i2 o
7 N. n% }4 l. R: j& T; ~* `
就是四个方块围绕中间点做顺时针转动(臭鸡蛋纷飞……),先别急,确实,这个变化太简化了,于我们的解题毫无帮助,不过先让我们为这种变换起个名字——“旋转”,然后我们再看看下面这个由几个“旋转”组成的“互换”吧(下图):
9 ?) f$ p5 t( X4 \9 P T 9 D* u) m7 }/ z2 m) m
在这个“互换”中涉及最少8个单元格,假设开始的排列如1所示,图中三个点击旋转的按钮姑且就叫做“上、中、下”吧,则步骤如下: $ @, l0 M; j' y1 l
(1-2):上×1 / X- N" Q3 \2 S6 R2 C
(2-3):下×3 4 g. [) [& t# w0 i) e5 F) f
(3-4):中×2
* {6 }; _" Y- f* l(4-5):上×3
; b `2 Y$ `* A* Q/ _* c(5-6):下×1
9 H; Y& X+ f: i7 n 是不是很有规律呢?按钮的顺序为“上下中上下”,点击(转动)的次数为“13231”,看看结果,对比1和6,我们在左列排列不变的基础上,把右列的上下部分互换了。
. S2 W6 v. X+ h2 e) G同样道理,我们也可以使右列保持不变,让左列的上下部分互换,唯一不同的是按钮顺序变为“下上中下上”而已,点击(转动)次数依然为“13231”。
8 \( t: t' ]6 a3 ~% ? 如果我们再把上图旋转90度,那么上下互换的操作同样也就适用于左右互换了,这个“互换”的操作不难吧?确定你要实行互换的行或列,根据下表找到第一个按钮,然后“13231”,搞定!] 0 ?8 v0 r6 j n/ u! F
2 d% `; b' J- y需要实现互换的列(行)的位置 对应第一个操作按钮的位置
5 u2 C: Y! `5 @' Y. l/ Y) K 左 下
& a' m! i2 S3 w c1 h7 s5 S8 R' e! u! E2 Z 右 上 0 C& U+ x9 @ n J* M+ k1 `
上 左
1 A% R6 Q! q; _( c3 W% G a 下 右
2 r# k* p. W t3 \7 |: S _; e, W( u, f& K" w" W' ^
好了,基础练习到此结束,下面是正题了。 - a1 i- H# }% Z) N% ~5 d
8 ~0 j, _( A' J# ~; V
, W; Q! N, V7 n# @! A+ J
任意变化 8 T- ~- Y1 \3 T+ n: ^( s. q3 m5 e: l
我们现在掌握了“互换”的秘密,有什么用呢?很重要,事实上,这类拼图迷题的全部变化,都是通过有限次的“互换”再加上1~2次“旋转”实现的。为什么这样说?还是以8个格子为例: % o" R/ @8 \" \
% B* Q" y2 @9 U 假设我们现在想重新设置e的位置,能否通过有限次的互换加1~2次旋转实现e的任意移动呢?答案是肯定的。 / w; Q* e$ i0 t4 ?& X" Q5 M. v
* 通过一次旋转,e能够到达现在c的位置,这绝对正确;
& v( P0 g" @/ }7 \% c* 通过一次互换,e能够到达现在a的位置,这一点也毫无疑问; , d+ n, U5 X) }
* 好了,如果e能到达c的位置,它再进行一次互换,就能够到达g; ; [: W3 c. w+ k% o
(至此,左列全部位置均能到达)
" n* B, C+ J7 w6 L! M/ g; { z* e能到达a位置,再进行一次旋转,则能到达b;
5 ^/ ?, Y9 P( ~3 w6 X* e在原位进行一次旋转,则到达f; 9 g/ b; {$ E* S- x8 @* N0 {
(现在剩下d、h位置了)
7 j/ }, e$ `4 v) V* e旋转两次可以到达d位置;
& \, g, U2 f* E) E2 F0 d* e在d位置上再加一次向下的互换,就轻松到达h。
* [4 g3 f' g) i( X ~ 通过以上步骤,我们让e遍历了全部位置,数一下,所有的过程都不超过有限次的互换和1~2次旋转,而且完全能在8个格子的范围以内实现。一幅任意大小(当然格子数要大于8)的矩形拼图都可以看作是好几个8格子单元的组合。
- J/ ?8 d& ~" c5 d' J* _/ u f 因此,理论上,通过有限次的互换和1~2次旋转可以任意变化拼图的排列。这里的“任意”,是指不考虑其他格子的情况,任意安排目标格子的位置。如果考虑其它格子的排列,在有限个格子的范围之内,全部格子的排列则不可能是任意的,例如:
# j/ z& M( R( p: k V9 g( A
. @7 k, \$ N# S, K1 S8 a 在这样的8个格子的限制之内,如果规定左列的顺序aceg不变,则右列的顺序只能为bdfh或fhbd,不可能有bfdh等其他的情况出现,姑且把这一条称之为“定理一”。 4 j; O$ O! C& ^: G" J* M3 {
不过我们其实不必为这种格子与格子之间排列方式的内在联系操心,因为我们可以这样考虑:现在的这个混乱的拼图其实是游戏制作者在整齐拼图的基础上通过和我们一样的规则变化出来的,因此,一切一切格与格之间内在的联系已经内含在拼图里了,无论拼图如何混乱,这种内在联系不会改变。所以我们只需专注于某一个格子的正确位置,其余的格子自然会按照这种内含关系发生改变。 |