冒险解谜游戏中文网 ChinaAVG

标题: [讨论]千奇百怪的Still Life迷题解法 [打印本页]

作者: uranus1997    时间: 2005-5-26 18:07
标题: [讨论]千奇百怪的Still Life迷题解法
<P>在游侠转了一下,发现still life里迷题的解法实在五花百门,挑了个我觉得比较“恐怖”的迷题解法,贴在这里给大家看看,也欢迎大家讨论分享自己的still life迷题解法[em01]</P>  J& P5 |, _6 _; k1 s0 l
<P>***********************************************************</P>
: x6 [# B2 A% z$ Z( ]0 }& C<P><FONT color=#ff0000><b>阁楼箱子的迷题</b></FONT></P>
. `* V& Y( H: @) R; \<P><FONT color=#2222dd>出自游侠[swiftxie]的解法:</FONT></P>
! r; o% E$ D$ Z$ [  ], X<P>这个迷题其实本身是很不错的,只是,谁知道要什么状况才可以打开箱子呢?
: V) f. f4 f2 M. S如果给我明确的目标,那么过程的思考是很有乐趣的,8 A# m+ n, U6 c5 h1 r/ n
可是没有明确的目标,谁知道阿?我于是第二次看了攻略,就看了要方方红方方才可以开。' Z( W0 s& O) o
然后是自己去摸索着转成方方红方方了。
2 P; h6 {. A& r摸索的过程还是比较有趣的,可以运用各种方法。2 q( |% X5 R$ m& _2 r0 l
也可以像我一样,模型化,编了个JAVA小程序解决。  Z4 ?' L) Q) g) A! T9 \2 h
当然我没有考虑最短路径,没有考虑重复的“环”情况。
  s. W0 y0 A+ K1 g那要编写的代码太多了,呵呵。反正只要求一个可接受的解就OK了么。
" k0 H+ w% j  G" \( Z( n如果是自己解,难度也不会太大,可以观察转动每个轴的变化情况,
) h7 u3 h9 l+ ?/ E; }用倒推的方法,3,4步一考虑。就是先跳3步,然后考虑,如果要这样,那么前三步大概如何。' a6 ?- X, w; z/ {8 P
在尝试的过程中,会发现一些“环”,就是若干步骤重复执行,会让状况回到开始。
# h+ A0 i6 G# G7 G6 u0 o这些环可以通过记忆避免,当然若是编程序,也无所谓环了。( h* z- j/ A' Y+ p/ @
(我当时的做法是50步一算,然后重新算一次50步,直到找到50步以内的路径,
( W. O" |& q- F3 F6 x这样,环最长,不会超过10步吧。)</P>
' n3 X. O7 Y3 P, U* j<P><FONT color=#3300ff>出自游侠[raycrisis]的解法:</FONT></P>1 d! T: U# A7 v' h6 U2 J
<P>没必要用JAVA编程序啊。: O" f! R2 u/ M, [8 a9 v; H1 [3 W
这是个矩阵求解的题目。
/ {7 p6 S$ M1 m用个矩阵除法一下就出来了。* j5 M% a3 i, G  ?, E
5个开关,4个花色。
: k! i% c; \' m( A4个花色风别代表4种状态。可设方块为1、梅花为2、红桃为3、黑桃为4。
, E6 k* Y6 Z9 a每个开关使用后,右转可代表1,左转可代表-1、不转代表0。' Z7 l2 l: v) ^. G. K
可得5X1的初始状态矩阵A,每个开关使用后的状态可得到一个5X5的矩阵B,每个开关需要使用的次数是一个1X5的矩阵X。要求开锁的状态也是一个5X1的矩阵C。
  n2 c; D6 u# }( Q6 N% {4 Q实际的方程就是A+X*B=C;" \* Y% G3 W/ g- |% ^( u
X=(C-A)/B;就可得到每个开关要使用的次数了。</P>  n# a5 ]) l/ g8 [6 N. y
<P>
3 |) P" I* Q# [. u3 `) t, m+ R得到的矩阵,如果是[0 -1 -1 -1 1]0代表不要使用,-1就是用3次(因为周期是4嘛),1就是用一次了啊。: A  ~3 R5 L* k1 o
这个矩阵很容易就能解出来。</P>
, b9 x: `4 K8 |<P>可是本人比较懒,用了matlab。</P>
" _3 m" D2 |4 Y- n<P>***********************************************************</P>0 d0 _. f+ z+ c$ S( u9 P* i
<P>真是恐怖啊,连JAVA和矩阵都出动了![em06]佩服之至!</P>1 r( T: D, [% Y5 \+ P- c$ w0 h
<P>大家还有一些别的迷题的思路吗?欢迎畅所欲言[em10]
- y1 x8 j0 U6 u. }4 ~</P>
+ Z" i+ B8 w7 P+ c8 N, ~* h7 F<P>9 o5 K* L3 ?6 [4 w" `8 b  i
</P>
作者: silverblue    时间: 2005-5-26 19:11
JAVA我不会啊,矩阵我们也未学过,而且我数学とても下手だね……
) b* W* `& Z+ x) r, v3 n: h
4 B! d2 l6 Z6 p( {7 n( Z0 X5 l我解这道题的时候,老是只能使红心的其中一边变成两个相同的花式,但是另一边就不能,尝试过和同房一个同学用画图表示,但越画越麻烦,而且他数学比我还要下手,所以我最后还是砰砰运气啦……2 u  X# E/ G4 H0 v
' e1 o$ k* B" x* ~4 _
不过我突然想起这道谜题有点像 Syberia 2 里面拆分火车车厢卡锁的那个机关,那个机关也是有五个活动轴,而且拉动一个就会影响另外几个,那个谜题我就是用画图列举情况的方法来解决的,但是那个谜题相比要简单一些,因为每个轴只有“升、降”两种情况,而still life这里每个轴有四种情况的……. {* i) J6 _, r6 p

% L) X; b: G) e  f. w5 [U姐你都没说你自己是用什么方法解出来的耶?
作者: abe_myth    时间: 2005-5-26 20:09
游侠那些人甚至有用编程解阁楼密码箱的[em24]
作者: silverblue    时间: 2005-5-27 02:40
我发现只有那些数学头脑很强的人的思维才会令阿U说“佩服之极”的
: H3 K+ `3 ?" C$ m, ]( s
" e' n4 d3 C4 f再去研究了这个阁楼宝箱谜题一翻,发觉真的不是画图可以解决问题的,除非画几十个图吧
0 I1 e3 ~) M: P8 X总之遇到这类排列组合的谜题,我真的宁愿碰运气好过了,反正我只是见到5个轴的转动方向是以中轴为对称的,但是再想下去就要爆血管,所以放弃,阿U你快说你是找什么规律解出来的?倒推吗?$ H. ~/ u6 n, [) p- a6 H7 l) {+ }
% u# C& U$ U5 h  a8 _& y4 L1 B& R
可惜俺高中时老师没教 矩阵 耶……9 G* q* ], j: W8 m8 t
没法了,习惯了应试教育,想学的又不考,不考的谁想学?[em01]
作者: abe_myth    时间: 2005-5-27 08:50
<P>矩阵是高等数学才学的,高中没有</P><P>不过应用简单的排列组合对应关系也可以很容易解开阁楼锁谜题</P>
作者: sjwings    时间: 2005-5-27 09:30
对擅长数学的人而言这种谜题就像做数学题,但用纯数学的方式解谜题我觉得就丢了游戏的乐趣了,还是喜欢用自己的方式……
作者: sliverblue    时间: 2005-5-27 11:08
提示: 作者被禁止或删除 内容自动屏蔽
作者: rb003    时间: 2005-5-27 21:21
<P>厉害……</P><P>这种谜题我都是猜着蒙出来的,没想过找最优解,平均10分钟搞定……</P>
作者: silverblue    时间: 2005-5-27 22:54
<DIV class=quote><B>以下是引用<I>rb003</I>在2005-5-27 21:21:20的发言:</B>   m) D) B0 h) T+ y
6 y" W4 H  n: [3 Q8 `+ K* D
  S0 B8 ~! x  U$ Z9 D2 `9 E& o
<P>这种谜题我都是猜着蒙出来的,没想过找最优解,平均10分钟搞定……</P></DIV>
2 z& |! F+ p; _# K; s. z0 o2 x$ @% g<P>啊..........这句话不要随便说啊.......
: N* C# V" f: |( F# d# d6 c" h* }; u! G+ [9 e1 ?
因为类似的话我对某人也说过啊,
% k$ `5 ]+ a" ?3 j$ ~, L9 b3 i; S6 Y+ a
结果就惹来大祸了.........[em01]</P>
& r( H1 }' u0 B- g0 J4 t# K' ?
[此贴子已经被作者于2005-5-27 22:57:16编辑过]

作者: pscj    时间: 2005-5-28 01:24
<P 0cm 0cm 0pt\">既然讨论我就来说说我的解法,没有游侠那人那么高深,一般人容易理解,就是麻烦点。
1 [) K' h9 v! S0 _; k4个花色风别代表4种状态。设方块为0、梅花为1、红桃为2、黑桃为3
/ T# y( {+ {6 u/ M/ D% v$ n搞一个数组存放箱子初始状态:int[] a = new int[] {0,2,0,3,1};& ^5 D) f8 j: [. H
最后我们要得到这样的结果:a={0,0,2,0,0}
% T  E; z4 ^4 x1 `( C4 T. R有5个开关代表5种情况,后面要排列组合用到。每个开关使用后,右转可代表1,左转可代表-1、不转代表0。以下是每转一次应该得到的新的结果。
8 d/ H+ h5 H% q1 k9 I! B(a +1) % 4 代表是右转+1       (a +3) % 4 代表是左转-1<p></p></P><P 0cm 0cm 0pt 84pt\">  _! O  [( O* C/ C( R% h. X/ ~
case 0:<p></p></P><P 0cm 0cm 0pt\">                                   a[1] = (a[1] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[2] = (a[2] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[3] = (a[3] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   break;<p></p></P><P 0cm 0cm 0pt\">                            case 1:<p></p></P><P 0cm 0cm 0pt\">                                   a[1] = (a[1] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[2] = (a[2] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[5] = (a[5] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   break;<p></p></P><P 0cm 0cm 0pt\">                            case 2:<p></p></P><P 0cm 0cm 0pt\">                                   a[4] = (a[4] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[2] = (a[2] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[3] = (a[3] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   break;<p></p></P><P 0cm 0cm 0pt\">                            case 3:<p></p></P><P 0cm 0cm 0pt\">                                   a[1] = (a[1] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[4] = (a[4] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[5] = (a[5] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   break;<p></p></P><P 0cm 0cm 0pt\">                            case 4:<p></p></P><P 0cm 0cm 0pt\">                                   a[4] = (a[4] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[5] = (a[5] +1) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   a[3] = (a[3] +3) % 4;<p></p></P><P 0cm 0cm 0pt\">                                   break;<p></p></P><P 0cm 0cm 0pt\">然后用多重循环对5种情况进行排列组合,最后判断看结果a={0,0,2,0,0} 成立否,不成立再增加循环次数,我试到10的时候得到结果的,就是10重循环。办法有点笨。矩阵没会用,数学不好,汗。。。<p></p></P>
作者: silverblue    时间: 2005-5-28 02:11
<P>pscj的方法我也看不懂啊........</P>
作者: XYZ    时间: 2005-6-3 15:58
看着象矩阵运算啊,我用matlab试试。。。
作者: kaese    时间: 2005-6-4 13:22
<P>直接用线性方程解啊。</P><P>第一个钮转a1下,第二第三第四依次为a2、a3、a4。</P><P>向左是-1,向右是1。</P><P>如此可以列出方程,</P><P>比如对于第一个钮,是要从方变到方,就是说不管怎么变,这个钮转动的次数总是4的倍数(向左四下或者向右四下)。因此如果要列出这个方程我们就要考虑影响第一个钮转动的几钟情况。</P><P>游戏删了不大记得谜题的具体内容了。</P><P>我就假设好了,</P><P>假设,</P><P>能够影响第一个钮转动的就是第一个钮,第二个钮,还有第四个钮,按第一个钮的时候1向左边转一下即-a1,按第二个钮的时候1向左边转一下又是-a2,按第四个钮的时候1向右边转一下即a4.</P><P>于是可以得到方程:</P><P>-a1-a2+a4=4n</P><P>依次类推把其它按钮的方程列出来,就可以解出来了:)</P>
作者: kaese    时间: 2005-6-4 13:24
<P>其实这四个方程列出来以后,用初中的方法加加减减就出来了,也用不到线性代数里的矩阵:)</P>
作者: silverblue    时间: 2005-6-4 16:30
<P>看来这位mm也是数学高手哦,佩服佩服</P>
作者: kaese    时间: 2005-6-4 19:25
<P>什么高手啊,</P><P>在玩到这个谜题的时候把表列出来,向左转就用-1表示,向右转就用1表示,</P><P>然后就很自然的想到线代了啊。</P><P>唉,偶的数学也就只能在这些很特别的情况下才能用到了,平常点的用常识解决,在特别点的就不会解决了[em11]</P>
作者: silverblue    时间: 2005-6-4 19:35
<P>线代我也没学过哦,所以也看不懂,我很讨厌数学啊,也很妒忌数学好的人啊 [em07]</P>
作者: oe    时间: 2005-6-9 12:25
<P>游戏是娱乐,学习累了来玩游戏,还要用学的数学[em06]</P><P>那不是被游戏玩了么?</P>
作者: 叉包饭斯    时间: 2005-6-12 14:52
楼上莫名其妙。- j! P' S9 A6 \5 H1 W7 M
) i+ @, p' ]; v3 N) _
数学是最有趣的游戏。
# Q: C: c' ~  M+ o5 E
, X9 r5 W' K: @. Z( M1 J( D3 a(虽然是我玩得最差的游戏)
作者: 燕鱼    时间: 2005-6-13 00:21
兄弟们,搞复杂了吧!
作者: windman    时间: 2005-6-15 22:47
这就是一个数学游戏。慢慢玩,不用这么复杂地算的。找到规律就行了。
作者: imcyn    时间: 2005-7-15 14:18
太强了,我是自己试出来的。
作者: eio    时间: 2005-8-13 19:20
这个矩阵解法太帅了 清晰高效啊
作者: lqshma    时间: 2005-8-26 03:59
我认为这个密题一定要发现他的规律,而这个规律也只能借助数学的方法 虽然按照规律试N次也可以试出来。
) [2 Z$ \4 q2 J# V
. r7 z9 l( P! n5 d
$ W( U$ \( r' k4 U( K: `
9 f" g$ r; Q6 F  y& s我们发现第一个开关控制的是1,2,3个字符的转动,而且分别是1,3右转 2左转' i1 ~1 Q; ?2 Y3 x. |, K* M4 u  R+ V
第二个开关控制的1,2右转  5左转
  K% n6 Z' W$ k! }  F/ m/ y第三个。。。第四 第五都可以发现他们控制的哪个字符转动以及方向+ J# \* w+ o" L  q( D
我们来列个表 1,2,3,4,5代表从做往右的5个开关 往右转用1 往左转用-1  填入下表8 L8 W* W+ z$ B
) @) y; J9 L+ r4 D

/ W1 w; e! t/ Q. e: g
* J' i: Y. Z' T7 u9 }7 @     1         2         3          4         5# E1 x* `% e: i( O. W: O
---|-----------------------------------------
2 D- E: _' ~; j% ]3 W* J7 Y1  |  1        -1         1                               a/ x6 j" X0 l0 I$ q/ g
---|-----------------------------------------
* q# g. p, h+ \& c2  |  1         1                               -1        b
5 V8 |9 X! v- j3 j---|-----------------------------------------
9 _  h0 l3 `! m  H$ S" s+ ~/ N+ Z- I3  |            -1         1         -1                   c9 m+ a6 R2 o. H& ?
---|------------------------------------------- \: ]. g5 f( z% M
4  | -1                                1         1        d
: X. }8 D% V6 {---|------------------------------------------* S- O* q& U  [, q$ Y) j) f# z( c
5  |                       -1          1         1        e5 [' G& m1 F+ Y5 D$ E) f' h2 D
----------------------------------------------
  M% u' t5 \) \/ k; X* r        0         2        2           1         3
: y$ A; L. r5 R  c7 j2 A, l, G- @2 `8 l: {' j; e* A+ c6 S8 F

% A5 l! a- \3 O  `4 A看到项链上的字符我们知道最后要摆成那几个字符 我们按照最初的情况知道总共需要让第1,2,3,4,5按钮分别右转0 ,2,2,1,3下,由于每个开关都互相影响,不能直接按开关1 0下,开关2 2下。。。。但是他们的影响有规律,就是上面的表,而且是线形的,所以可以通过解方程
: `. d+ o! h  ~# L# ?设第一个开关按a下,第二个开关按b下,。。。c,d,e ,1 V$ ^2 e4 \$ {+ U- n' Y7 D
. y6 @9 Z, J3 h2 v# t0 b$ \3 L
下面要做的就是列方程了 从上往下竖着看
9 u# v7 R( y% {5 o1 z% g4 u  Ta+b-d=0. V4 h. u6 W2 I% _
-a+b-c=2. E4 h# A+ b4 E$ Q* D4 O1 u
a+c-e=2
/ k2 c  B4 Q* ^1 s& D" V-c+d+e=1' {' f- _! k  r% `4 e
-b+d+e=3
) w) H9 R% t* O( x1 }4 \5 U% w, S3 a
: o+ b* J. f% K, X, U- I* ]$ n这个方程应该很好解,要是不会解或者懒得解的话你就给你上小学的弟弟妹妹做做练习
8 |/ O8 Y6 n: I0 W+ |, T. \9 R得出来的a,b,c,d,e就是开关1-5所按的次数$ N7 _; |  I+ O4 w: R, {

8 s* \; J+ d. u# V" Y; ~$ ~: u- `; E% t& ~5 K+ @4 f) y
不知道我讲明白没有
5 [) Q0 N; S' s1 s5 P# l- N3 W! Y- N: \! K) H8 Y; H
. x* T9 E3 ]  Y$ j2 ?
如果学过线性代数的话就知道 其实解线性方程和做矩阵运算是一回事,但这么一个小CASE就要搬出矩阵这个工具来解决未免太夸张了吧,而且还要做复杂的矩阵变换,太麻烦了,虽然可以用Matlab算,但游戏玩家大多不会用的吧* b" |4 Y4 o5 @& C: }
5 p: D& }5 Z7 {; f( e+ a3 I. S
还有人居然想到编程,太BT了吧
作者: uranus1997    时间: 2005-8-27 14:20
哇哇,给lqshma鼓掌,我喜欢你的解法,够简单而有逻辑,思路也很清晰!
作者: lqshma    时间: 2005-8-27 17:46
过奖 过奖
( _/ L$ Z2 x  Z2 B7 R! n( U3 A1 i8 b0 C7 w, ^7 R7 ?" x/ V( L

+ x7 U& v+ k! }3 N  \2 q+ ~
+ E: f' w3 W$ C/ |: f' A3 f) F$ l, K2 V# {0 Y

$ V0 s# G4 A0 H  |& L0 O& u怎么我列的表格变形了?奇怪!




欢迎光临 冒险解谜游戏中文网 ChinaAVG (https://chinaavg.com/) Powered by Discuz! X3.2