古代先民认为,天下万物皆由五类元素组成,分别是金、木、水、火、土,彼此之间存在相生相克的关系。
相生关系为:木生火,火生土,土生金,金生水,水生木。
相克关系为:金克木,木克土,土克水,水克火,火克金。
本题就请你编写程序,判断任意一对给定的元素之间的关系。
输入格式:
输入在一行中给出一个正整数 N(≤10),随后 N 行,每行给出
2 个正整数 A 和 B,为两种元素的编号。这里假设金、木、水、火、土的编号顺次为 1、2、3、4、5。
输出格式:
对输入的每一对 A 和 B,如果 A 生 B,则输出 A sheng B;如果 A 克 B,则输出 A ke B。反之亦然。
输入样例:
2
4 2
5 3
输出样例:
2 sheng 4
5 ke 3
分析:
根据题意,金木水火土相生相克关系如下:
相邻元素相生,间隔元素相克,唯一的问题就是题目中12345是金木水火土,规律中顺序是金水木火土。所以使用数组将给的元素对应到规律中的顺序中去。
由于是5个元素循环,所以数组中的数字都以5取余。
实验代码:
#include<stdio.h>
#include<math.h>
int main() {
int x[5] = {1,3,2,4,0};
int n, a, b;
scanf("%d",&n);
for (int i = 0;i < n;i++) {
scanf("%d %d", &a, &b);
if (abs(x[b - 1] - x[a - 1]) == 1) {
printf("%d sheng %d\n", (a<b)?a:b, (a<b)?b:a);
}
else if(abs(x[b - 1] - x[a - 1]) == 2) {
printf("%d ke %d\n", (a<b)?b:a,(a<b)?a:b);
}
}
return 0;
}