`

(转)信息数字化解逻辑题分享

    博客分类:
  • java
阅读更多

 

转自:http://www.iteye.com/topic/695360

 

1. 前提条件:

   将逻辑题目中的信息用数字化描述。

2. 范例:

(1) 例1:
 
    问题描述: 警察局抓了a、b、c、d四名偷窃嫌疑犯,其中只有一人是小偷。审问结果如下。

               a说:"我不是小偷。"
               b说:"c是小偷。"
               c说:"小偷肯定是d。"
               d说:"c在冤枉人。"
             
               现在已经知道4个人中3人说的是真话,一人说的是假话,问到底谁是小偷?



   问题分析:将a、b、c、d四人进行编号,分别为1,2,3,4。
             用x存放小偷的编号,则x的取值范围从1~4。
             4个人所说的话可以分别写成:
             a说的话:x != 1
             b说的话:x == 3
             c说的话:x == 4
             d说的话:x != 4


   代码如下:

package boke.written;

public class InfoToNumber {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		int x;
		
		for (x = 1; x <= 4; x++) {
			int s = 0;
			
			if (x != 1) {
				s++;
			}
			
			if (x == 3) {
				s++;
			}
			
			if (x == 4) {
				s++;
			}
			
			if (x != 4) {
				s++;
			}
			
			if (s == 3) {
				char ch = (char) (64+x);
				System.out.println(ch + "是小偷");
			}
		}

	}
}

    输出结果:C是小偷

    


(2) 例2:

    问题描述: 3位老师对某次数学竞赛进行了预测。他们预测的结果如下。
               甲说:学生A得第一名,学生B得第三名。
               乙说:学生C得第一名,学生D得第四名。
               丙说:学生D得第二名,学生A得第三名。

               竞赛结果表明,他们都说对了一半,说错了一半,并且无并列名次,求A、B、C、D各自的名次。


    问题分析: 用数字1、2、3、4来表示学生A、B、C、D获得的名次。
               甲说的话:(A == 1) + (B == 3) = 1;
               已说的话:(C == 1) + (D == 4) = 1;
               丙说的话:(D == 2) + (A == 3) = 1;
               由于无并列名次,四个人的名次之和等于10 = 1 + 2 + 3 + 4。

   代码如下:

public class InfoToNumber2 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		int A,B,C,D;
		
		for (A = 1; A <= 4; A++) {
			for (B = 1; B <= 4; B++) {
				if (A != B) {
					for (C = 1; C <= 4; C++) {
						if ((C != A) && (C != B)) {
							D = 10 - A - B -C;
							if ((D != A) && (D != B) && (D != C)) {
								boolean bool1 = false;
								boolean bool2 = false;
								boolean bool3 = false;
								
								if ((A == 1) || (B == 3)) {
									bool1 = true;
								}
								
								if ((C == 1) || (D == 4)) {
									bool2 = true;
								}
								
								if ((D == 2) || (A == 3)) {
									bool3 = true;
								}
								
								if (bool1 == true && bool2 == true && bool3 == true) {
									System.out.println("A = " + A + " B = " + B + " C = " + C + " D = " + D);
								}
								
							}
						}
					}
				}
			}
		}
	}
}

 输出结果:A = 4 B = 3 C = 1 D = 2


  

              

分享到:
评论
1 楼 hnzhoujunmei 2010-09-08  
,为什么发了两遍代码

相关推荐

    数字逻辑试题及答案数字逻辑试题及答案数字逻辑试题及答案

    【数字逻辑试题解析】 数字逻辑是一门研究数字信号处理的学科,主要涉及数字系统的分析、设计和实现。在本试题中,我们涵盖了多个关键概念,包括数字表示、逻辑门、编码器、时序逻辑电路、计数器、数据选择器、...

    数字逻辑习题+答案

    通过对上述选择题的解析,我们不仅回顾了数字逻辑的基础理论,还深入探讨了电路设计的具体应用。数字逻辑的学习不仅仅是理论知识的记忆,更是解决问题能力的培养。通过大量的练习和实践,考生可以更好地掌握数字逻辑...

    数字逻辑试题数字逻辑试题1

    根据给定的数字逻辑试题的信息,我们可以从中提取和总结出一系列重要的数字逻辑知识点。下面将对这些知识点进行详细的解释和扩展。 ### 数字逻辑基础知识 #### 1. 数制转换 - **八进制转十六进制**:题目中的第一...

    数字逻辑电路习题答案

    "数字逻辑电路习题答案" 数字逻辑电路是计算机科学和电子工程中的一门重要课程,涉及到计算机系统的设计和实现。本资源提供了数字逻辑电路习题的答案,涵盖了数字逻辑电路的基础知识,如二进制数的表示、补码的定义...

    数字逻辑教材习题答案

    《数字逻辑教材习题答案》是一份专门为学习数字逻辑课程的学生准备的学习资源。这份资料集包含了大学数字逻辑课程中常见的习题解答,旨在帮助学生深入理解课程内容,提高解题能力,为考试和后续的学习打下坚实的基础...

    数字逻辑复习题————————

    【数字逻辑复习题】 在数字逻辑领域,复习题通常涵盖基础概念、运算规则以及问题解决技巧。这些题目旨在帮助学习者巩固对数字系统、逻辑门、布尔代数、二进制转换、组合逻辑电路和时序逻辑电路的理解。 【例1】将...

    数字逻辑训练100题

    《数字逻辑训练100题》是一份专为提升逻辑思维能力设计的训练材料,尤其适合准备面试或者希望增强逻辑推理技巧的人群。这100道题目旨在通过数字和逻辑的结合,锻炼你的分析、判断和解决问题的能力,让你在面对复杂...

    (数字逻辑)试卷2019版--带答案

    数字逻辑试卷2019版--带答案的题目涵盖数字逻辑的基础知识和应用,包括数字信号和数字电路的设计和分析、逻辑门和数字电路、数制转换、触发器和寄存器、数字逻辑应用等。这些题目可以帮助学生和工程师检验自己的数字...

    数字逻辑与数字系统设计习题参考答案.doc

    《数字逻辑与数字系统设计习题参考答案》 在学习数字逻辑与数字系统设计时,理解和掌握各种计算方法是至关重要的。本习题集旨在帮助学生巩固基础,提高解决实际问题的能力。以下是对部分习题的解答和解析。 1.3 ...

    数字逻辑试题与答案.doc

    《数字电路与逻辑设计》试题解析 一、填空题 1. 逻辑函数的一般表达式可能不是唯一的,但其标准表达式如最简与或式或最简与非与或式是唯一的。 2. 任意两个最小项之积为0,任意两个最大项之和为1。 3. 在逻辑函数...

    数字逻辑电路期末考试

    《数字逻辑电路》是计算机科学与工程领域中的基础课程,主要研究数字信号的处理、转换和传输。在期末考试中,学生通常会面临各种概念、原理、设计方法以及实际应用的考核。以下是对数字逻辑电路相关知识点的详细阐述...

    数字逻辑欧阳星明_数字逻辑_数字逻辑pdf_

    《数字逻辑》是电子工程和计算机科学领域的重要基础课程,主要研究数字信号的处理、变换和控制。欧阳星明编著的《数字逻辑》是一本深入浅出的教材,为学习者提供了全面而系统的数字系统设计知识。这本书的PDF版本为...

    数字逻辑与数字系统习题1

    《数字逻辑与数字系统》习题解析 一、填空题 1. 在数字系统中,负逻辑体制中,逻辑“1”通常用低电平表示,如0V;而逻辑“0”则用高电平表示,如5V或3.3V。 2. 7个1进行异或运算的结果为0,因为任何数与自身异或...

    数字逻辑练习题与答案

    从给定的文件信息来看,这是一份关于数字逻辑的基础学习资料,包含了多个章节的练习题及答案,涉及了数字逻辑的基本概念、原理及其应用。下面是对这些知识点的详细解析: ### 第一章:数字逻辑基础 #### 一、选择...

    计算机数字逻辑复习题(有试卷)

    计算机数字逻辑是计算机...通过这份数字逻辑复习题,学习者可以检验自己的理解,查漏补缺,进一步提升在数字逻辑领域的理论知识和实践技能。在解答过程中,不仅要注意理论知识的运用,还要锻炼逻辑思维和问题解决能力。

    数字电子技术 数字逻辑 (全英文) 课后习题答案

    《数字电子技术与数字逻辑——全英文课后习题答案详解》 在深入探讨数字电子技术和数字逻辑领域时,理解并掌握课后习题的答案至关重要。这份由专业教师提供的、详细且权威的英文课后习题解答文档,是学习过程中不可...

    数字逻辑与数字系统_自测试题库

    自测试题库针对以上知识点提供了丰富的练习题,涵盖理论和应用两方面,帮助学生全面掌握数字逻辑与数字系统的核心概念和实际应用。通过这些题目,学生可以自我检测学习进度,找出知识盲点,从而提高学习效果。在实际...

Global site tag (gtag.js) - Google Analytics