【智力题 02】猜名次

@TOC


【02 猜名次】

5位运动员参加了跳水比赛,有人让他们预测比赛结果:
A选手说:B第2,我第3
B选手说:我第2,E第4
C选手说:我第1,D第2
D选手说:C最后,我第3
E选手说:我第4,A第1
比赛结束后,每位选手都只说对了一半,请编程确定比赛的名次。


一、分析

我们已知的信息:
1、有5名选手,那么名次就是是1 2 3 4 5
2、每位选手都只说对了一半,即ABCDE 5个人的预测中,1句为真,1句为假,(1 + 0 == 1)

二、转化成编程语言

我们假设,预测对的是1,预测错的是0。
对A、B、C、D、E 5个人进行一次遍历,每个人获得名次的可能性都是1-5,进行5层循环的嵌套。再通过(1 + 0 ==1)的条件进行判断。
具体代码如下:

#define _CRT_SECURE_NO_WARNINGS 1
#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++)    // 5层for循环嵌套,  abcde从1-5名遍历
	{
		for (b = 1; b <= 5; b++)
		{
			for (c = 1; c <= 5; c++)
			{
				for (d = 1; d <= 5; d++)
				{
					for (e = 1; e <= 5; e++)
					{
						//5个条件
						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)
						{
							if (a*b*c*d*e == 120) 
							{
								printf("A = %d B = %d C = %d D = %d E = %d\n", a, b, c, d, e);
							}
						}
					}
				}
			}
		}
	}
}

总结

这道题有一个难点,如果仅仅是满足(1+0 ==1),会有很多种答案,但是很明显最终的答案只能有一个,所以需要添加一个限制条件,使得1-5中的名次只能各被1个人取得1次,即1X2X3X4X5=120。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值