用编程来做逻辑题
怎样用程序来实现编程题呢?最暴力的方法当然是穷举了,我们可以利用计算机超快的计算能力来实现。
下面是两个例子
第一题
5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果:
A选手说:B第二,我第三;
B选手说:我第二,E第四;
C选手说:我第一,D第二;
D选手说:C最后,我第三;
E选手说:我第四,A第一;
比赛结束后,每位选手都说对了一半,请编程确定比赛的名次。
代码如下
#include<stdio.h>
int main()
{
int A = 0;
int B = 0;
int C = 0;
int D = 0;
int 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) &&
(A * B * C * D * E == 120))
printf("A=%d,B=%d,C=%d,D=%d,E=%d\n", A, B, C, D, E);
}
}
}
}
}
return 0;
}
运行结果如下
第二题
日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个嫌疑犯的一个。
以下为4个嫌疑犯的供词:
A说:不是我。
B说:是C。
C说:是D。
D说:C在胡说
已知3个人说了真话,1个人说的是假话。
现在请根据这些信息,写一个程序来确定到底谁是凶手。
代码如下
#include<stdio.h>
int main()
{
int killer = 0;
for (killer = 'a'; killer <= 'd'; killer++)
{
if ((killer != 'a') + (killer == 'c') + (killer == 'd') + (killer != 'd') == 3)
{
printf("凶手是:%c\n", killer);
}
}
return 0;
}
运行结果如下