题目----who is the killer?

简介: 题目----who is the killer?

题目

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

A说:不是我。

B说:是C。

C说:是D。

D说:C在胡说

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

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

解析

//已知3个人说了真话,1个人说的是假话。
//所以根据逻辑推出如果某人说了假话,那么其他人说的都是真话;否则还得继续判断谁说了假话。
//那么也可以反过来看也就是只有当有三个人说了真话的时候才成立,据此我们要判断当凶手是谁的时候有三个人说了真话。
//
//现在请根据这些信息,写一个程序来确定到底谁是凶手。
//
//由于三个人说了真话,所以B和C之间必定有一个人说了假话。则A和D说的都是真话,可以初段排除A,D不是凶手
//既然D说的是真话,那么C说的就是假话,所以B说的也是真话,所以凶手是C
//
int main() {
    int killer; // 凶手编号
    int real;// 说真话的人数
    for (killer = 1; killer <= 4; killer++)
    {
        real = (killer != 1) + (killer == 3) + (killer == 4) + (killer != 4);
        if (real == 3)
        {
            printf("凶手是:%c\n", killer + 64); // 输出凶手的ASCII码值对应的字母,A对应65,B对应66,依次类推
            break;
        }
    }
 
    return 0;
}
目录
相关文章
|
存储 缓存 算法
LeetCode刷题---Two Sum(一)
LeetCode刷题---Two Sum(一)
|
5月前
|
算法
【动态规划专栏】专题三:简单多状态dp--------3.删除并获得点数
【动态规划专栏】专题三:简单多状态dp--------3.删除并获得点数
49 1
|
2月前
|
前端开发
LeetCode------移动零(5)【数组】
这篇文章介绍了LeetCode上的"移动零"问题,提出了一种使用双指针的原地操作解法,该方法首先将非零元素移动到数组前端并保持相对顺序,然后填充后续位置为零,以达到题目要求。
|
5月前
|
算法 C语言
Leetcode----旋转数组 ------C语言篇
Leetcode----旋转数组 ------C语言篇
|
2月前
|
存储
LeetCode------斐波那契数列(2)
这篇文章提供了解决LeetCode上"斐波那契数列"问题的两种方法:一种是使用备忘录模式通过递归计算并存储结果以避免重复计算,另一种是自底向上的迭代方法,同时要求结果对1e9+7取模。
LeetCode------斐波那契数列(2)
|
4月前
|
C语言
C语言------猜数字游戏----有次数限制版
C语言------猜数字游戏----有次数限制版
|
5月前
题目----从小到大输出
题目----从小到大输出
26 0
|
5月前
题目----逆序
题目----逆序
26 0
|
5月前
力扣每日一题 ---- 2918. 数组的最小相等和
力扣每日一题 ---- 2918. 数组的最小相等和
|
存储 C语言
C语言程序设计-----猜数字游戏(1A2B详解)
C语言程序设计-----猜数字游戏(1A2B详解)
373 0