`
kofsky
  • 浏览: 202724 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

求解一个简单的逻辑题

阅读更多
引用
逻辑题:请编程实现,时间一小时。
某天!一家珠宝公司被盗!警方怀疑是甲,乙,丙,丁四个人中的一个,因此对四人进行问话。
甲说:我不是强盗! ,乙说:丁是强盗,丙说:乙是强盗,丁说:我不是强盗
这四个人中只有一人说的是真话。请问谁是强盗!?


我想的是
设置四个bool变量,分别为A,B,C,D
为true表示其为强盗,为false表示不是强盗
其中只有一个为true,三个为假
将四个人的话语分别转换成逻辑语句:
甲说:我不是强盗! 表达式x A == false
乙说:丁是强盗     表达式y  D == true
丙说:乙是强盗     表达式z  B == true 
丁说:我不是强盗   表达式w  D == false
由于四个人只有一个是真话,也就是说,这四个表达式xyzw,也只有一个为true
由于表达式y与w完全相反,因此必有一个为真
因此表达式 x,z 必定都为假
也就是说 A == true, B == false
甲为强盗


在ChinaUnix上看到另外一个人的解答,用公式推出的,彪悍些:
引用

不编程行不行?用一对布尔变量来描述一个人的状态 (v0, v1),  v0=0 表示说假话,1 真话;v1=0 表示非强盗,v1=1 表示强盗。

按我对题目的理解,强盗只有一人,说真话的也只有一人。设甲乙丙丁分别为 x,y,z,w,有:

x1=x0+1
w1=w0+1
w1=y0
y1=z0

把中间两个式子一加得到 w0+y0+1=0, 所以 w0,y0 中有一个是 1, 另一个是 0;
但 x0,y0,z0, w0 中只有一个 1, 所以 x0=z0=0;
由第一个式子可知道 x1=1

甲是强盗。

分享到:
评论
4 楼 ibio 2009-04-23  
呵呵。强悍,顶!~
3 楼 shellkk 2008-07-18  
要求的应该是让程序自己推理吧。一小时能做出来也太牛了吧,化合取范式和归结反演的算法写起来都挺绕的。
2 楼 ham 2008-07-17  
bcccs 写道
甲说:我不是强盗! ,乙说:丁是强盗,丙说:乙是强盗,丁说:我不是强盗
这2句话互为逻辑反,必有真话,所以其他的都是假话,所以甲是强盗。
编程?都想出来了,编程算什么?

这话说得..
那我叫你打印一个3X3的正方形.
直接
System.out.println("* * *");
System.out.println("* * *");
System.out.println("* * *");

不就完了.还用得着绕循环么?
1 楼 bcccs 2008-07-08  
甲说:我不是强盗! ,乙说:丁是强盗,丙说:乙是强盗,丁说:我不是强盗
这2句话互为逻辑反,必有真话,所以其他的都是假话,所以甲是强盗。
编程?都想出来了,编程算什么?

相关推荐

    智能问题求解课件

    在这个“智能问题求解课件”中,我们可以深入探讨多种策略和技术,包括搜索方法、归结原理、群集智能以及遗传算法等。 1. **搜索方法**:搜索方法是人工智能中最基础的问题求解技术之一。它通过在问题的状态空间中...

    迷宫求解问题

    在计算机科学领域,迷宫求解问题是一个经典的图论问题,它涉及到路径寻找、搜索算法等多种概念。在这个问题中,我们通常将迷宫视为一个二维矩阵,其中每个节点代表一个位置,而路径则由可通行的节点(通常是1或true...

    回溯法求解骑士巡游问题

    这是一个典型的组合优化问题,没有简单的公式可以直接求解,因此常常采用搜索算法来寻找解决方案,其中之一就是回溯法。 回溯法是一种试探性的解决问题的方法,它尝试通过逐步构造可能的解决方案来探索问题的所有...

    开源求解器SCIP的python接口学习手册

    SCIP(Solving Constraint Integer Programs)是一个开源的数学优化求解器,用于解决混合整数规划问题。Python 是一种流行的编程语言, PySCIPOpt 是 SCIP 的 Python 接口,提供了一个易于使用的 API,允许用户使用 ...

    猴子摘香蕉问题求解完整代码

    利用一阶谓词逻辑求解猴子摘香蕉问题:房内有一个猴子,一个箱子,天花板上挂了一串香蕉,其位置如图1所示,猴子为了拿到香蕉,它必须把箱子搬到香蕉下面,然后再爬到箱子上。请定义必要的谓词,列出问题的初始化...

    感知器求解逻辑分类问研究题的

    ### 感知器求解逻辑分类问题方法研究 #### 1. 单层感知器求解逻辑“与”和逻辑“或”问题 感知器是一种简单的线性分类模型,最初由Frank Rosenblatt在1950年代提出。单层感知器通过调整权重来学习如何将输入映射到...

    基于LINGO的优化问题动态规划法求解

    以最短路问题为例,考虑一个由城市节点构成的网络,其中的边代表城市之间的距离。目标是找出从起点城市到终点城市的最短路径。这个问题可以通过动态规划的前向递推策略来解决。设定D(i, j)表示从节点i到节点j的最短...

    C++完美实现一元三次方程求解

    接着,我们要设定一个搜索区间,该区间保证至少包含一个函数零点。然后,根据二分法的步骤,不断将区间分为两半,检查中间点是否满足方程,并依据中间点的函数值调整搜索区间。当区间足够小,可以认为中间点即为方程...

    数独求解程序游戏设计报告书

    数独(Sudoku)是一种逻辑填数字游戏,玩家需按照一定的规则在9×9的网格内填入1至9的数字,使得每一行、每一列以及每一个3×3的小宫格内的数字都不重复。数独游戏不仅能够锻炼人的逻辑思维能力,还能提高解决问题的...

    迷宫求解——栈的简单应用

    `Simple.java`可能是一个简单的测试类,用于创建迷宫实例,调用迷宫求解的方法,并打印出解法。它会帮助我们验证迷宫求解算法的正确性。 栈在迷宫求解中的应用体现了其在路径搜索中的优势,因为栈的特性使得我们...

    SAT和SMT求解器简介:Introduction to SAT and SMT Solvers

    SAT求解器处理的是布尔逻辑问题,即确定一组布尔变量的赋值是否存在使得所有布尔表达式都为真。它们在硬件验证、软件测试、电路优化等领域有广泛应用。而SMT求解器则更进一步,它结合了SAT求解器的基本功能与特定...

    基于DPLL算法的SAT问题求解器【100012387】

    SAT(Boolean Satisfiability Problem)问题,即布尔可满足性问题,是计算机科学中一个重要的NP完全问题。它的核心是判断一组布尔变量的公式(通常以CNF,即合取范式表示)是否存在一种赋值方式,使得所有子句都为真...

    高等应用数学问题的MATLAB求解光盘

    本书首先介绍了MATLAB语言程序设计的基本内容,在此基础上系统介绍了各个应用数学领域的问题求解,如基于MATLAB的微积分问题、线性代数问题的计算机求解、积分变换和复变函数问题、非线性方程与最优化问题、常微分...

    excel2003中用于规划求解的宏加载项

    例如,在财务管理中,可能需要在有限的资金下,最大化投资回报,这就是一个典型的规划求解问题。 安装规划求解宏加载项的过程如下: 1. 下载规划求解的压缩包文件,如"SOLVER"。 2. 解压缩文件,通常会得到一个...

    tsp问题贪心算法求解

    总结来说,这个压缩包包含了一个使用贪心算法求解旅行商问题的C语言程序,以及相关的项目文件和输入数据。尽管贪心算法无法保证找到TSP的全局最优解,但对于小型问题实例,它仍然能提供一种接近最优的解决方案。对于...

    excel2007的规划求解的使用

    Excel 2007 的规划求解功能是一个强大的数据分析工具,尤其适用于解决资源分配和优化问题。在这个功能的帮助下,用户可以设定目标并约束条件,让Excel自动找出最佳解决方案。以下是对规划求解使用的详细说明: 首先...

    求解逻辑回归问题的多层邻近拟牛顿算法.docx

    目前,求解逻辑回归问题的算法有很多,如快速迭代收缩阈值算法、邻近拟牛顿算法、交替方向乘子法、随机坐标下降算法等,其中邻近拟牛顿算法是求解复合凸优化问题的一类重要方法。Becker 等利用对偶问题的分段线性...

    【数学建模】基于整数规划完整的制作一个数独求解器(附MATLAB代码).zip

    数独是一种广受欢迎的逻辑游戏,它通过填充一个9×9的网格,使得每一行、每一列以及每一个小的3×3宫格内的数字都从1到9不重复出现。这个压缩包文件“【数学建模】基于整数规划完整的制作一个数独求解器(附MATLAB...

    基于sat的二进制数独游戏求解程序课程设计 .zip

    一个数独游戏可以被表示为一组逻辑约束,这些约束可以通过布尔变量和它们之间的逻辑关系(如AND、OR、NOT)来描述。当我们把数独盘面的每个空格看作一个布尔变量,若某格填入数字i,则对应布尔变量设为true,反之设...

    论文研究-可满足性问题全部解的求解算法.pdf

    SAT问题在人工智能、计算机基础...利用一个简单的变换,将可满足性(SAT)问题转化为多项式形式,然后根据命题逻辑的性质以及多项式的性质,得到一个求解出SAT问题所有解的算法。实验结果显示该算法是有效和可行的。

Global site tag (gtag.js) - Google Analytics