c语言:通过加以真假限制的条件来预测结果(五名运动员跳水和日本谋杀案为例)

简介: c语言:通过加以真假限制的条件来预测结果(五名运动员跳水和日本谋杀案为例)

解题方法固然很重要的,思考的过程更重要,只有去自己思考,才能发现其中的奥妙。

就拿五名运动员跳水排名为例

5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果:

            A选手说:   B第二, 我第三;

            B选手说:  我第二, E第四;

            C选手说:  我第一,D第二;

            D选手说:   C最后, 我第三;

            E选手说:我第四,A第一;

比赛结束后,每位选手都说对了一半, 请编程确定比赛的名次。

我们来思考,既然是五位运动员,那么A,B,C,D,E分别都有第1,2,3,4,5这五中可能。

若A说的第一句话中前半句话为“B第二”,也就是B==2,后半句为”我第三”,也就是A==3

我们知道在c语言中:   一个条件表达式如果为,则返回1;

                    如果为,则返回0;

而ABCDE当中每人都只说对了半句话,所以每个选手的两个条件表达式的返回值之和就为1

以此类推,BCDE也同样如此,于是按思路就可以写出:

#include<stdio.h>
int main()
{
  int a, b, c, d, e = 0;
  for (a = 1; a <= 5; a++)
  {
    for (b = 1; b <= 5; b++)
    {
      for (c = 1; c <= 5; c++)
      {
        for (d = 1; d <= 5; d++)
        {
          for (e = 1; e <= 5; e++)
          {
            if (
              (((b == 2) + (a == 3)) == 1) &&
              (((b == 2) + (e == 4)) == 1) &&
              (((c == 1) + (d == 2)) == 1) &&
              (((c == 5) + (d == 3)) == 1) &&
              (((e == 4) + (a == 1)) == 1) )
              printf("%d %d %d %d %d", a, b, c, d, e);
          }
        }
      }
 
    }
  }
  return 0;
}
 
 


运行程序发现:还多了这么多数据,筛除不合理排名(例如12131中,有三个排名第一则没有第三名和第二名,如果不同排名较多可以利用编程筛除);筛除后

还剩下 1 2 5 2 2  

    3 1 1 3 4

    3 1 5 2 4 ;经过对比ABCDE五位选手每句话直说对半句的条件,由于题目没有说明是否可以拿相同名次,因此都符合条件,结果都为正确答案,

若必须出现1-5的名次,则可以在if判断语句中加上

&&(a*b*c*d*e == 1 * 2 * 3 * 4 * 5)来限制每一位的排名不重复

则结果就仅为3 1 5 2 4(分别对应ABCDE的排名)。


日本谋杀案同样如此


日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个嫌疑犯的一个。


以下为4个嫌疑犯的供词:


A说:不是我。


B说:是C。


C说:是D。


D说:C在胡说


已知3个人说了真话,1个人说的是假话。


现在请根据这些信息,写一个程序来确定到底谁是凶手。


和上面一题类似,我们可以 设凶手为0,不是凶手则为1;

A说不是A自己,则表明A==1,B说是C,则表明C==0;

以此类推四个人所表明的四个表达式就为 A==1;C==0;D==0;D==1

这四个表达式中有3个为真,1个为假,这说明四个表达式的返回值之和,为3。

而凶手又必然是四个人当中的一个,则表明三个人的值为1,一个人的值为0;

于是就有A+B+C+D==3;综合下来可以写出

//}0是 1不是
#include<stdio.h>
int main()
{
  for (int a = 0; a < 2; a++)
  {
    for (int b = 0; b < 2; b++)
    {
      for (int c = 0; c < 2; c++)
      {
        for (int d = 0; d < 2; d++)
        {
if ((((a == 1) + (c == 0) + (d == 0) + (d == 1)) == 3) && (a + b + c + d == 3))
            printf("0为凶手a=%d b=%d c=%d d=%d", a, b, c, d);
        }
      }
    }
  }
}

于是就可以判断凶手是谁。

目录
相关文章
|
5月前
|
人工智能 移动开发 算法
【2023华中杯数学建模】B 题 小学数学应用题相似性度量及难度评估详细建模方案及实现代码
本文提供了2023年华中杯数学建模B题的详细建模方案和实现代码,包括设计小学数学应用题相似性度量方法、建立题目难度评估数学模型、对题库进行相似性或难度分类,以及使用TF-IDF和K-Means聚类算法进行题目难度分析和相似题目推荐。
86 0
【2023华中杯数学建模】B 题 小学数学应用题相似性度量及难度评估详细建模方案及实现代码
|
8月前
日拱一卒,月进一步(6)(杨辉三角2)
119. 杨辉三角 II - 力扣(LeetCode)
51 0
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)-1
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)
197 0
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)-1
|
测试技术 Windows
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)-2
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)
149 0
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)-2
|
机器学习/深度学习 测试技术
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)-3
第十二届蓝桥杯决赛JavaC组真题——详细答案对照(全网唯一:异或变换100%数据)
290 0
|
开发工具
数理逻辑之 自然演算规则(三)
截止到前文数理逻辑之 自然演算规则(二),我们已经学习了四种7个命题逻辑的自然演算规则,分别是合取规则、双重否定规则、蕴含消去规则、MT规则。 接下来我们要学习的规则不仅从规模上看起来比前面的要大,理解和使用上也提升了难度。
1354 0
数理逻辑之 自然演算规则(三)
|
开发工具
数理逻辑之 自然演算规则(二)
今天继续说自然演算规则。 不过说之前先说一点题外话:每个人都有自己喜欢的东西,虽然大家都是搞开发的,不过最喜欢的也很可能不一样。你是牛人我也是牛人,只不过我们牛逼的地方不一样,我们都没有必要为了超过对方而去努力学习自己不稀罕的东西。
1282 0
数理逻辑之 自然演算规则(二)
数学分析高等代数考研试题荟萃[更新至2017年12月15日]
需要请点击链接.   10001北京大学2016-2017-1高等代数I期末考试试题   10001北京大学87,96-14,17年数学分析考研试题 (05含解答)   10001北京大学96-02,05,07,08,10-14 年高等代数考研试题   10002中国人民大学99,0...
2427 0