5位运动员参加了10米台跳水比赛,有人让他们预测比赛结果:
A选手说:B第二,我第三;B选手说:我第二,E第四;C选手说:我第一,D第二;D选手说:C最后,我第三;E选手说:我第四,A第一;比赛结束后,每位选手都说对了一半,请编程确定比赛的名次。
#include <stdio.h>
#include <windows.h>
void Game()
{
int a = 1;//利用5个for循环把所有的可能列出来
for (; a <= 5; a++){
int b = 1;
for (; b <= 5; b++){
int c = 1;
for (; c <= 5; c++){
int d = 1;
for (; d <= 5; d++){
int e = 1;
for (; 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)
{
unsigned char flag = 0; //0000 0010
flag |= (1 << (a - 1));//利用flag讲选手名次写入0的二进制中
flag |= (1 << (b - 1));
flag |= (1 << (c - 1));
flag |= (1 << (d - 1));
flag |= (1 << (e - 1));
while (flag)
{
if (!(flag & 1))//检测是否镂空,在二进制上检测
{
break;
}
flag >>= 1;//若低位二进制为一,便向前进一位,在再检测下一位是否连续
}
if (!flag)//若到现在后面为0,即是不存在镂空(所谓的镂空便是如10001这样的,即不是连续的,五个人不可能同时第二,第三,第四,第五,且不会存在一个第一,其余第五的现象。)
{
printf("a: %d, b: %d, c: %d, d: %d, e: %d\n", a, b, c, d, e);
}
}
}
}
}
}
}
}
int main()
{
Game();
system("pause");
return 0;
}