关于编程之美一个房间里面三盏灯的问题

                这几天在看编程之美这本书。这里面提到了一个非常有意思的问题。"房间里面有三盏灯,屋外有三个开关,分别控制三盏灯,只有进入房间,才能看到哪一个电灯是亮的,请问如何进入房间一次,就能指明哪一个开关控制哪一个灯?”我想了一个解法,未必正确,各位浏览的博友可以思考一下。如果我的答案有误,欢迎批评指正,如果其他解法,欢迎共同讨论,最好把自己的思考过程写出来,大家共同进步。

    我的思考过程是这样的,一般要想知道哪个开关控制哪个灯,观察的变量是灯亮不亮。但是在这道题里面有了限制,因为要辨别的是三盏灯,而且只能进入房间一次。如果只有灯亮不亮这个变量去判断哪个开关控制哪盏灯,显然只能知道三个开关中的一个控制哪盏灯,剩下的两盏无法判别,因为他们同暗或同亮。原本我的思考方向是,人在做这件事的时候只有三个动作,第一个,在进入房间之前可以去操作开关,第二个,进入房间之后可以观察灯或者做其他一些小动作,第三个,出来后可以操作开关。显然出来之后无论如何操作开关,都无法观察灯的状态,所以解题的关键应该在第一和第二步。我之前都是在第二步里面思考。想过在第一步里面开两个开关,关掉一个开关,进入房间之后知道一个开关控制哪盏灯,然后对亮着的两盏灯进行操作,可以影响到开关的状态。思考很久,不知道怎么进行,房间里面的灯如何才能影响外面开关的状态呢?后面我才想到,我的思考重心错了,我应该把重点放在第一步。而且不能只以一个变量去解决这个问题。因为这里面有三盏灯,就像数学里面的问题。有两个未知数,自然需要两个变量去解方程。有了这个思路,答案就呼之欲出了,灯除了发光,还能发热,节能灯之类的,在灯关掉之后,还会有一点点荧光,这些都是解题的关键。所以我的答案是,刚开始的时候,打开开关1,等十分钟,关掉,打开开关2,保持开关3的关闭状态。进入房间,亮着的灯对应开关2,暗着的灯里面,有微微荧光或者灯泡发热的灯对应开关1,另外一盏对应开关3。至此,就是我的全部思考过程和最终答案。大概历时一个钟。

    思考的过程是有趣的。欢迎大家共同讨论。互相关注,一起交流,共同进步。

  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
环境:Windows XP SP3、 VC++ 6.0、 Windows 2003 SDK 使用步骤: 1、下载解压之后,使用VC++ 6.0打开两个工程:一个是SocketServer和一个ClientSocket工程。 2、首先运行服务器端工程,选默认的端口1008 3、然后运行客户端工程,选默认的端口1008和默认的服务器地址 4、再运行多个客户端进程 5、如果一切正常,可以每个客户端的消息发送,我们可以在服务端和各个客户端同步看到消息 实现一个服务器对多个客户端的关键是,在服务端的使用集合CPtrList类用保存客户端的socket对象,思想与Java中的编程思想一样,只不过Java中会使用多线程技术,在Vector集合保存客户端的socket对象,而MFC框架提供了CSocket类,它是一个异步通信的类,所以看上去代码比较Java的多线程代码简单的实现了一个对多的即时通讯功能。另外,MFC提供了CSocketFile类和CArchive类与CSocket类实现了C++的网络通讯编程功能。 本示例注释非常详细,所有的辅助类都放一个util目录中,然后在工程中分了一个目录来管理这些辅助类,使用代码非常清晰。手动书写部分的代码是按Java的规范书写,当然其它代码由IDE生成的,所以是MS的风格,所以当你看代码时,只要是使用“骆驮命名法”的方法都是本人书写的功能性代码。 参看的思路:在服务端要从回调方法onAccept读起;而客户端代码主要从OnSendButton方法读起,即可理解整个代码的意思。 阅读对象:具有Java的Socket编程经验的人员,并且希望能够书写出比Java效率更高的即时通讯程序的人员

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

javacankillyou

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值