(2)练习题——B相生相克(C语言思路讲解)

该文提供两种C语言解决方案,用于判断根据五行理论(金、木、水、火、土)中任意两种元素之间的相生或相克关系。程序通过枚举法和创建关系数组来实现关系判断,并输出相应结果。

古代先民认为,天下万物皆由五类元素组成,分别是金、木、水、火、土,彼此之间存在相生相克的关系。

相生关系为:木生火,火生土,土生金,金生水,水生木。

相克关系为:金克木,木克土,土克水,水克火,火克金。

本题就请你编写程序,判断任意一对给定的元素之间的关系。

输入格式:

输入在一行中给出一个正整数 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

一、C语言代码

1、枚举法

#include <stdio.h>

int main( )
{
    int A , B;  int n = 0;    int i = 0;
    scanf("%d\n",&n);
    for(i=0 ; i<n ;i++)
    {
    scanf("%d",&A);
    scanf("%d",&B);

    if((A==1&&B==2)||(A==2&&B==1))
    {
        printf("1ke2\n");
    }
    else if((A==2&&B==5)||(A==5&&B==2))
    {
        printf("2ke5\n");
    }
    else if((A==3&&B==4)||(A==4&&B==3))
    {
        printf("3ke4\n");
    }
    else if((A==4&&B==1)||(A==1&&B==4))
    {
        printf("4ke1\n");
    }
    else if((A==5&&B==3)||(A==3&&B==5))
    {
        printf("5ke3\n");
    }
    
    else if((A==1&&B==3)||(A==3&&B==1))
    {
        printf("1sheng3\n");
    }
    else if((A==2&&B==4)||(A==4&&B==2))
    {
        printf("2sheng4\n");
    }
    else if((A==3&&B==2)||(A==2&&B==3))
    {
        printf("3sheng2\n");
    }
    else if((A==4&&B==5)||(A==5&&B==4))
    {
        printf("4sheng5\n");
    }
    else if((A==5&&B==1)||(A==1&&B==5))
    {
        printf("5sheng1\n");
    }
    }
    return 0;
}

2、思路法

#include <stdio.h>

int main(int argc, char const *argv[])
{
    int ch[6] ={0,1,2,3,4,5}; //金木水火土

    int sheng[6] ={0,3,4,2,5,1};//金木水火土sheng水火木土金
    int ke[6] ={0,2,5,4,1,3};//金木水火土ke木土火金水
   
   int n =0; int i = 0; int a = 0; int b = 0;

   scanf("%d\n",&n);

   for(  i   =  0  ;  i  <  n ;  i++)
   {
        scanf("%d %d",&a,&b);
        if(sheng[a] == b)
        {
            printf("%dsheng%d\n",a,b);
        }
         if(sheng[b] == a)
        {
            printf("%dsheng%d\n",b,a);
        }
        if(ke[a] == b)
        {
            printf("%dke%d\n",a,b);
        }
         if(ke[b] == a)
        {
            printf("%dke%d\n",b,a);
        }
   }
    return 0;
}

二、输出结果

1、枚举法输出结果

2、思路法输出结果

所提供的引用中未涉及C语言实现五行学说相关功能的方法和代码。不过可以从五行学说的基本概念出发,提供一个简单示例。五行学说中五行存在相生相克的关系,相生关系为:金生水,水生木,木生火,火生土,土生金;相克关系为:金克木,木克土,土克水,水克火,火克金。 以下是一个用C语言实现判断五行相生相克关系的简单代码示例: ```c #include <stdio.h> #include <string.h> // 定义五行枚举类型 typedef enum { METAL, // 金 WATER, // 水 WOOD, // 木 FIRE, // 火 EARTH // 土 } FiveElements; // 获取五行对应的枚举值 FiveElements getElement(const char *element) { if (strcmp(element, "金") == 0) return METAL; if (strcmp(element, "水") == 0) return WATER; if (strcmp(element, "木") == 0) return WOOD; if (strcmp(element, "火") == 0) return FIRE; if (strcmp(element, "土") == 0) return EARTH; return -1; } // 判断相生关系 int isGenerating(FiveElements first, FiveElements second) { return (first == METAL && second == WATER) || (first == WATER && second == WOOD) || (first == WOOD && second == FIRE) || (first == FIRE && second == EARTH) || (first == EARTH && second == METAL); } // 判断相克关系 int isOvercoming(FiveElements first, FiveElements second) { return (first == METAL && second == WOOD) || (first == WOOD && second == EARTH) || (first == EARTH && second == WATER) || (first == WATER && second == FIRE) || (first == FIRE && second == METAL); } int main() { char firstElement[10], secondElement[10]; printf("请输入第一个五行元素(金、水、木、火、土): "); scanf("%s", firstElement); printf("请输入第二个五行元素(金、水、木、火、土): "); scanf("%s", secondElement); FiveElements first = getElement(firstElement); FiveElements second = getElement(secondElement); if (first == -1 || second == -1) { printf("输入的五行元素有误,请输入金、水、木、火、土。\n"); } else { if (isGenerating(first, second)) { printf("%s 生 %s\n", firstElement, secondElement); } else if (isOvercoming(first, second)) { printf("%s 克 %s\n", firstElement, secondElement); } else { printf("%s 与 %s 无相生相克关系\n", firstElement, secondElement); } } return 0; } ``` 此代码定义了五行的枚举类型,通过输入两个五行元素,判断它们之间的相生相克关系并输出结果。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值