两个乒乓球队进行比赛,各出三人。甲队为 a,b,c 三人,乙队为x,y,z 三人。已抽签决定 比赛名单。有人向队员打听比赛的名单。a 说他不和 x 比,c 说他不和 x,z 比,请编程序找出 三队赛手的名单。
参考 https://blog.csdn.net/lsx2596/article/details/109212225
思路:
如果不编程的话一眼就能看得出来谁和谁比。写代码的话需要三层循环,在最内层把谁不和谁比的条件加上。第二层第三层还得排除一下找到一样的比赛对手的情况。
三层循环的流程大概是这个样子:
假设a的对手是x,在这个条件下假设b的对手是x,此时a,b对手相同,不行。再假设此时b的对手是y,假设c的对手是x,a,c对手相同不行。在假设c的对手是y,b,c对手相同不行。在假设c的对手是z。此时不满足a的对手不为x。再次走到第一层循环,假设a的对手为y…直到找到满足所有条件的情况。
#include <stdio.h>
int main()
{
//i 是 a 的对手,j 是 b 的对手,k 是 c 的对手
char i, j, k;
for (i = 'x'; i <= 'z'; i++)
for (j = 'x'; j <= 'z'; j++)
{
if (i != j)
for (k = 'x'; k <= 'z'; k++)
{
if (i != k && j != k)
{
if (i != 'x'&&k != 'x'&&k != 'z')
printf("a--%c\tb--%c\tc--%c\n", i, j, k);
}
}
}
return 0;
}