服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言猜凶手及类似题目的实现示例

C语言猜凶手及类似题目的实现示例

2022-08-14 10:39Naion C/C++

本文主要介绍了C语言猜凶手及类似题目的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

描述:

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

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

A说:不是我。        

B说:是C。

C说:是D。

D说:C在胡说

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

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

思路及分析:

        从来没有做过类似题目的同学第一次看见这道题,可能有点发懵。然后开始考虑假设,排列组合,枚举等等...但是这道题的代码结果会让你大吃一惊。

        首先,要考虑的是如何用代码表示A,B,C,D这四个人说的话?我们定义一个char变量killer来表示凶手。最能想到的就是如果某个人说的话是成立的话,将他的结果为1(类似于bool类型),否则就是0。这样的想法是正确的。A说,不是A,那么,可以表示为killer != ‘A’。判断成立的话,他就会返回1,否则,返回0。类似的,其他3个人说的话也可以这样来表示。最后,根据3个人说了真话,1个人说了假话得知返回的总和为3。比如,我们假设A就是凶手,那么根据四个人说的话,A说了假话,B也说了假话,和条件是不符合的。这样之后,只是判断了A的情况,B,C,D的情况还没有判断,只需要加一个循环就可以了。

        C语言代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include<stdio.h>
 
int main(void)
{
    char killer = 'A';
    for (killer = 'A'; killer <= 'D'; killer++)
    {
        if ((killer != 'A') + (killer == 'C') + (killer == 'D') + (killer != 'D') == 3)
        {
            printf("the killer is %c", killer);
        }
    }
 
    return 0;
}

        结果如下:

C语言猜凶手及类似题目的实现示例

现在,我们来看和它相似的第二道题目:

描述:

        两个乒乓球队进行比赛,甲队为ABC三人;乙队为XYZ三人;抽签决定比赛名单,有人向队员打听比赛的名单,A说他不和X比,C说他不和Z比。请编程输出所有可能的对阵方案,并统计方案的个数。

思路及分析:

        这道题和猜凶手那道题目的方法是一致的,都是直接把题目的文字描述转换为代码描述。直接使用 for循环即可。代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include<stdio.h>
 
int main(void)
{
    char A = 0;
    char B = 0;
    char C = 0;
        for (A = 'X'; A <= 'Z'; A++)
        {
            for (B = 'X'; B <= 'Z'; B++)
            {
                for (C = 'X'; C <= 'Z'; C++)
                {
                    if ((A != 'X') + (C != 'Z')  == 2)
                    {
                        if (A != B && B != C && C != A)
                        {
                            printf("A VS %c, B VS %c, C VS %c\n", A, B, C);
                        }
                        
                    }
                }
            }
        }
    return 0;
}

        结果如下:

C语言猜凶手及类似题目的实现示例

第三道题目:

描述:

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

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

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

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

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

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

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

思路及分析:

        暴力破解法即可。代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include<stdio.h>
 
int main(void)
{
    int a = 0, b = 0, c = 0, d = 0, 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第二,我第三
                            ((b == 2) + (e == 4) == 1) && //我第二,E第四
                            ((c == 1) + (d == 2) == 1) && //我第一,D第二
                            ((c == 5) + (d == 3) == 1) && //C最后,我第三
                            ((e == 4) + (a == 1) == 1))   //我第四,A第一
                        {
                            if (a * b * c * d * e == 120)
                            {
                                printf("%d %d %d %d %d\n", a, b, c, d, e);
                            }  
                        }
                    }
                }
            }
        }
    }
    return 0;
}

C语言猜凶手及类似题目的实现示例

总结:

最后一道题目来看,出现了惊人的五个for循环。同时,每一个for循环都是循环5次,时间复杂度达到了O(n * n)。也就是说,一旦要判断的人数增多,计算机的计算速度将会以肉眼可见的速度慢下去。类似的题目采用暴力破解的方法虽然不是最优解,但却是最直观简单,好理解的方法。 

到此这篇关于C语言猜凶手及类似题目的实现示例的文章就介绍到这了,更多相关C语言猜凶手内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/Naion/article/details/121884821

延伸 · 阅读

精彩推荐
  • C/C++C语言文件读写操作介绍与简单示例

    C语言文件读写操作介绍与简单示例

    这篇文章主要给大家介绍了关于C语言文件读写操作的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    风知我意否10652021-10-19
  • C/C++C/C++程序编译流程详解

    C/C++程序编译流程详解

    C/C++程序编译过程包括下面4个阶段:1.预处理,2.编译,3.汇编,4.链接。下面我们就来详细分析下这几个阶段。...

    Lynn-Zhang9542021-03-30
  • C/C++VSCODE调试RDKit内核的方法步骤(C++)

    VSCODE调试RDKit内核的方法步骤(C++)

    本文主要介绍了VSCODE调试RDKit内核的方法步骤,这个过程可以分为三个部分:安装 RDKit 所需环境,安装 VSCode 相应插件, 写调试代码编译,感兴趣的可以了...

    Zealseeker''s Blog9902021-12-21
  • C/C++C语言实现歌曲信息管理系统

    C语言实现歌曲信息管理系统

    这篇文章主要为大家详细介绍了C语言实现歌曲信息管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    hackbuteer18752021-06-18
  • C/C++C++ pair的基本用法总结整理

    C++ pair的基本用法总结整理

    这篇文章主要介绍了C++ pair的基本用法总结整理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面...

    sevencheng7985472021-09-15
  • C/C++DSP中浮点转定点运算--举例及编程中的心得

    DSP中浮点转定点运算--举例及编程中的心得

    本文主要讲解DSP浮点转定点运算举例及编程中的心得 ,具有参考价值,需要的朋友可以参考一下。...

    ganxingming11452021-04-07
  • C/C++C语言实现扫雷小游戏简单版

    C语言实现扫雷小游戏简单版

    这篇文章主要为大家详细介绍了C语言实现扫雷小游戏简单版,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    Stout80011612021-12-08
  • C/C++数据结构与算法:单向链表实现与封装

    数据结构与算法:单向链表实现与封装

    今天小编就为大家分享一篇关于数据结构与算法:单向链表实现与封装,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟...

    蜗牛20112152021-07-15