设为首页收藏本站官方微博

技巧 AVG迷题探索(02)

[复制链接]
查看: 13639|回复: 28
打印 上一主题 下一主题

[技巧] AVG迷题探索(02)

跳转到指定楼层
楼主
发表于 2007-8-21 13:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

AVG迷题探索(02)


- H  L: [% l5 K* ]
5 a  z$ V. |/ T- R - ]8 R8 A  m% B

) M% Z4 E$ u  n& R
: T$ G! g5 F7 i+ i7 n3 X3 G5 g; g' B- r. m- I( w
        破箱人中的这个迷题颇为有趣,如果我们换个角度来思考,把进入迷题时各灯泡的状态看作一幅图画,而把电源接通后各灯泡的状态也看作一幅图画的话,那么这道迷题也可以当作是一幅“拼图”类型迷题吧~不过这个“拼图”却不是靠“移动”各部分来“拼”成的,而是依靠“旋转”各部分来“拼”成的。
: v# z3 h( Q: f+ n  O# ]        如果各行列的旋转按钮不像现在一般有个指针的话,即使我们能够看到这个拼图的最终状态,我们有把握把它拼好么?恐怕不是每个人都有肯定的回答。 : q: @( {2 j  I# p
这个迷题的变化真的如此复杂吗?事实上这却是一个最最简单的拼图迷题,为什么?请看下面的分析。
( X7 W6 j& E1 i/ B4 Q        这类迷题和其他拼图迷题的产生方法是一样的,都是在整齐拼图的基础上,由迷题作者通过使用和游戏者一样的操作方式随意变动而产生的。那么先让我们看看迷题作者对这幅拼图的变动产生了什么效果。
( Z3 m* J1 a( K' _3 h# ~! m# D/ \2 w: i9 k$ ^1 y( T, f/ E7 n

9 }/ H5 Q1 f  K5 J' e
, C/ G* t$ u" A1 o        迷题作者通过点击每一行或列上的旋钮来旋转该行或列的全部方格,因此我们可以用上表来表示全部方格的变化情况。假设全部方格的初始状态为0(即没有经过旋转),然后方格每被旋转一次,它的状态数值就增加1,最后表上的数字就能很清楚的显示出迷题作者对拼图做过什么手脚了。 4 B4 }5 }) c6 }1 Z8 ^0 q
/ o6 W) L& {  r$ ^, C6 R' K1 F
1 B! T, O) Y- f9 G2 ]$ w
9 X' D! q9 W, Q3 O" O
        例如作者对A列做了两次旋转,对5行做了一次旋转,表格的表示就如上图所示,可以看到行列相交的方格A5因参与了两次调整,故已经旋转3次了。 / S) ]/ y; b2 t7 O3 H- {- {
        于是,作者就开始对这个表格(也就是迷题本身)做随意的调整了:
3 `2 F. E" X1 O1 i: ~) W+ G$ I$ E
2 k) I0 U5 o! I- r* f( Z& K% H  { 3 {* s2 C6 z9 ^! F- x
( T  G5 Z$ h9 S2 L. j( A, f
        呵呵~现在简直就是一团糟嘛,作者的任务就完成了,游戏上市,摆在我们面前的就是这“一团糟”的东西,怎么办? : h! @' e6 P! D! P1 N# u
        看着上面这些毫无规律的数字当然头痛,但应该记住,上面的数值只表示每个格子经过了几次旋转,但并不代表格子的状态。实际上因为是正方型的格子,所以格子的状态只有4种而已。因此我们可以先通过一些转换,把表示旋转次数的数字变为表示状态的数字,方法是把上图数字对4取模(即与4相除取其余数),于是得出: 3 I7 T# r7 t  N7 A7 [; I; o

8 D& q9 n3 N" ~- g; @" H
* X2 j# `  n/ b. j0 N; k* M, q7 z9 h* E& q
        现在的画面好看很多了,每个数字1、2、3、0分别代表该方格处于的不同状态,很显然,我们需要做的就是让全部数字归0,这样就能把拼图复原成初始状态了。所谓“归0”,就是继续旋转数字为“1、2、3”的格子,使其累加转动次数变成4(记住:状态4=状态0)。 , ]2 E: v1 a8 n$ J/ Q( v  {
" Q* H$ q2 V$ o5 j+ y
      这里介绍一种极其简便的“归0”方法:选定任一行或任一列为目标,先把它全部归零,然后再调节其他的列或行,这样每行/列的旋转次数都不需要超过3次就可以解决问题了。还是以上图为例,假设我们选择先调整E列:
6 A  j2 z% t$ R( U/ c8 z' ~
  g  K! |) B" l: v. b4 l; A % D4 a2 G% |& I. k# }0 m7 z
# g% g5 ]0 U! n3 N, W+ N! s
        我们通过点击按钮1两次,使行1的全部方格转动两次,E1的状态即由2转为0(4)了。同理我们通过按动按钮2~8,把E列的全部方格“归0”,
( P- q( g5 w- m  ^) O
; F; h$ Y$ B3 c' a$ M8 B 9 R9 p  Q, b" F8 Z
! c) p/ Y0 A( H) s3 ]# I& c. m, w
        看到了,结果很神奇对不对?尽管我们只把注意力放在E列上,可是当把E列全部“归0”后,其他列上的方格居然也自动排列得整整齐齐了。
2 Y) f- ]5 R/ D* `' M# L7 j4 o2 H        剩下的工作就是通过A~H几个按钮,把不为0的列转过来就好了。
; c' r8 f0 [5 Z  @( h# l
) \! o$ o7 h( ~8 a# X7 q, T1 h        上面的方法可不是碰巧的呀,如果有朋友表示怀疑,说我们是碰运气,那请继续看下面的证明。
# F* x6 P4 F# J; o6 S* r+ P+ g/ s( t: T; \8 _! D/ p& n
( F5 T. b4 Q& ^  ~9 w) d% n
(附上一个excel小程序,各位可用来测试本文内容)

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 很美好很美好 很差劲很差劲
回复

使用道具 举报

沙发
 楼主| 发表于 2007-8-21 14:00 | 只看该作者
证明:1 S, c& F% d+ a3 N9 A, `. M
% L, |6 [) o: z% F( d5 g$ s
. `: i0 x: d* B& y) J; X6 N
' W+ C/ c' p) ^
        假设作者在打乱拼图时,对每一列的转动次数为x1~x8,每一行的转动次数为y1~y8,那么每个方格转动的次数可以在上图这样表示出来。和前面的步骤一样,我们对全部方格的转动次数对4取模:
0 m' m* l( q. S1 q2 ?1 O( ^$ U1 @
# e1 A3 [. e0 m
- \, i+ ]6 B6 D: K# {- d7 D# @$ S! \8 D) [  _* m
        还是和刚才一样,我们随便选一列,譬如x5列为第一目标进行“归0”。以x5y1格为例,该格子现在的状态是(x5+y1) mod 4,那我们要调整y1多少次呢?设调整次数为Δ1,则:0 [" Q6 `$ e, z: m- W* N6 S% B% L& e
                                               ((x5+y1)mod 4 +Δ1)mod 4 = 0$ P' ]- u: {, }$ l; }0 N: g) }8 a5 l
# R1 ]2 k/ v0 w5 v8 ^
        因为:: T7 }+ z& P9 E4 u3 a& F/ H
                                                              (x5+y1)mod 4 < 4
7 a% b+ @1 K5 y; x& ~8 P
8 {. Z6 _$ }: A$ P3 |4 m* o6 A! I        所以上面方程可转化为:
" F# l8 C8 t5 o: e4 i4 n                                                         (x5+y1)mod 4 +Δ1 = 42 r4 H( C( v) s3 M* m8 c* l5 ?/ O
3 M1 N- e4 D5 z, K  e' [6 q
        所以调节次数Δ1等于:
# ]+ d% P0 o! o2 ?' p) G                                                          Δ1 = 4 -(x5+y1)mod 4
$ R, i; R/ E6 m- |$ P, r6 ]2 D! L9 i
        按照方程结果,旋转y1行Δ1次,则y1行全部方格的状态变为(全部列出太长了,截选一个方格来说明):, x( n& D" |/ F- i
    x1y1方格:, t6 h2 V) E9 R* `$ a3 r4 k
                                               (x1+y1) mod 4 + 4 -(x5+y1)mod 4
- R% d8 i1 B9 ?' |& y1 H8 u1 i8 @5 g: _  o+ o  G( B/ g; D/ V
        为了表示出方格状态,上式必须再对4取模:* Q0 g9 I  C% p, G
                                      ((x1+y1) mod 4 + 4 -(x5+y1)mod 4)mod 4! p; m& w8 f& @8 T
- W1 T, j9 k* S' Q5 {
        简化一下:
% P  T7 u" m; h* T                                                        (x1+y1 - x5 - y1) mod 4
8 o4 H# Y# c. y
- t9 C+ l6 Q  _- J* p5 [2 }$ H        于是x1y1的状态为:" m9 o* j7 t' V/ O7 g2 U4 P2 o% h
                                                            (x1 - x5) mod 4
4 F) Y3 W  [' o# S* j! x  F; `        / ]8 r& M0 ?7 }9 b9 a: g) `/ S, a
        同理我们可以得到调整后y1行全部方块的状态如下:. Y4 l/ l; }! n) U7 Q* k4 Q
1 O' x5 |' Q8 |- x. p+ y" t7 f: e
, `$ U2 \" k! S: A0 q

' Y4 n' v5 Y8 S1 z! k$ ~* Z同样的方法,我们可以算出y2~y8行的旋转次数Δ2~Δ8,并使整个矩阵的状态变为:
$ D* b: B% f& D% D6 X; ~! L
- L  A' v/ H1 l5 K3 @
( }2 y: A" Q+ H, E% p+ v- y
: M/ W% Z7 q: M* T        可以清楚看到,现在同一列上的方格都处在同一状态之下,这和我们实例中的结果是一致的。证毕!
3 y! Y" P' r- q+ L, v2 _) ?# h+ [% E, N/ h$ d2 ^

0 O0 o* h! C0 n8 q    好了,这条迷题的分析只能到这里为止,实际上我们分析的只是这一类迷题中格子的旋转规律,通过这种规律总结出一般的方法,使用此方法可以迅速把迷题调节到解决状态,但前提是我们事先知道“解决状态”的图案。
* t& ?& R$ C' r% ~, G! a: x, P9 e    9 o5 N& _# E3 K
    所以,很遗憾,虽然我们找到旋转规律,却仍无法解决破箱人这道迷题,因为刚刚面对时我们跟本不知道“解决状态”是什么样子的。呵呵~我们架起了桥梁,可不知道对岸在哪。这个问题小弟实在还没解决,请高手来指教了!
回复 支持 反对

使用道具 举报

板凳
发表于 2007-8-21 14:33 | 只看该作者
我顶  tabris你也忒牛了吧
回复 支持 反对

使用道具 举报

地板
发表于 2007-8-21 14:34 | 只看该作者
学了两年的高等数学都看不懂  我要仔细研究下
回复 支持 反对

使用道具 举报

5#
发表于 2007-8-21 14:45 | 只看该作者
我的高等数学
1 k( q. m" C4 o/ ~/ W0 T4 s! Q
* {# ^4 ]9 v( X' P' [
0 d. O- k8 R3 E* ^简直没学过
回复 支持 反对

使用道具 举报

6#
 楼主| 发表于 2007-8-21 15:13 | 只看该作者
向soring救助,我贴子里附的excel小程序不能锁定,请你下了看看怎样修改才行。谢谢啦~
回复 支持 反对

使用道具 举报

7#
发表于 2007-8-21 15:14 | 只看该作者
我草[s:15] ~tabris你是搞得越来越虚幻了~
, v9 G5 o, x, N6 @9 }. v, |感慨完了再慢慢看~~~
回复 支持 反对

使用道具 举报

8#
 楼主| 发表于 2007-8-21 15:19 | 只看该作者
其实可以不看后面的证明的,那个东西我都觉得很烦,把附件下载了点点就完全能够明白什么意思了哦 [s:1]
回复 支持 反对

使用道具 举报

9#
发表于 2007-8-21 15:37 | 只看该作者
晕 完全不会用excel 看得出tabris已经是高手了
回复 支持 反对

使用道具 举报

10#
 楼主| 发表于 2007-8-21 15:41 | 只看该作者
没办法呀~工作需要,每天必用EXCEL,是个宝
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

冒险解谜游戏中文网 ChinaAVG

官方微博官方微信号小黑屋 微信玩家群  

(C) ChinaAVG 2004 - 2019 All Right Reserved. Powered by Discuz! X3.2
辽ICP备11008827号 | 桂公网安备 45010702000051号

冒险,与你同在。 冒险解谜游戏中文网ChinaAVG诞生于2004年9月9日,是全球华人共同的冒险解谜类游戏家园。我们致力于提供各类冒险游戏资讯供大家学习交流。本站所有资源均不用于商业用途。

快速回复 返回顶部 返回列表