你有没有从梦中醒来,然后发现你真的还在做梦?如果你醒来,你怎么知道你回到了现实?这个难题实现了该问题的解决方案:当您进入和退出梦想时,您可以计算梦境的递归级别:
<b>package</b> sleep; <b>import</b> dream.Dream; <b>public</b> <b>class</b> Sleeper { <b>private</b> <b>int</b> level; <b>public</b> <b>synchronized</b> <b>int</b> enter(Dream dream) { level++; <b>try</b> { dream.dream(<b>this</b>); } <b>finally</b> { level--; } <b>return</b> level; } }
睡眠者开始睡觉并进入梦境(第一级)。他可以在梦里做一个梦,甚至进入更深层次的梦。但当他离开表层的梦时,他再次醒来,所以他应该再次回到零级,对吧?
<b>package</b> sleep; <b>import</b> dream.Dream; <b>public</b> <b>class</b> Main { <b>public</b> <b>static</b> <b>void</b> main(String[] args) { <b>if</b> (<b>new</b> Sleeper().enter(<b>new</b> Dream()) != 0) { <font><i>// The goal is to reach this line</i></font><font> System.out.println(</font><font>"Am I still dreaming?"</font><font>); } } } </font>
levels 计数看起来非常安全,所以这似乎是不可能的:
<font><i>// this is the only file you're allowed to edit</i></font><font> <b>package</b> dream; <b>import</b> sleep.Sleeper; <b>public</b> <b>class</b> Dream { <b>public</b> <b>void</b> dream(Sleeper s) { </font><font><i>// TODO implement me</i></font><font> } } </font>
你能找到这个推理中的缺陷吗?你能想象一个真正奇怪的梦想会让睡眠者失去理智吗?