C语言编程精选6 十二生肖

现在需要统计一个组的人的生肖相同的个数,生肖有以下十二个:Rat(鼠)、Ox(牛)、Tiger(虎)、Rabbit(兔子)、Dragon(龙)、Snake(蛇)、Horse(马)、Goat(羊)、Monkey(猴子)、Rooster(鸡)、Dog(狗)、Pig(猪)。要求生肖相同的人的个数最多的排在前面,如果生肖相同的人的个数也相同则按照字典序列排序(也就是生肖字母排序)。详细请看输入、输出样例。

输入格式:首先输入一个正整数n,然后再输入n组数据,输入的每组数据包含了姓名和生肖两个信息。

输入样例:

5

Tom Rat

Bob Ox

John Goat

James Ox

David Rat

输出样例:

Ox2

Rat 2

Goat 1

#include <stdio.h>
#include <string.h>

// 定义生肖数组
const char* zodiacs[] = {"Rat", "Ox", "Tiger", "Rabbit", "Dragon", "Snake", "Horse", "Goat", "Monkey", "Rooster", "Dog", "Pig"};
const int NUM_ZODIACS = 12;

struct ZodiacCount {
    const char* zodiac;
    int count;
};

// 函数:比较两个生肖的顺序
int compareZodiac(const void* a, const void* b) {
    const struct ZodiacCount* zc1 = (const struct ZodiacCount*)a;
    const struct ZodiacCount* zc2 = (const struct ZodiacCount*)b;
    
    if (zc1->count != zc2->count) {
        return zc2->count - zc1->count; // 按照个数从大到小排序
    } else {
        return strcmp(zc1->zodiac, zc2->zodiac); // 如果个数相同,则按照字典序排序
    }
}

int main() {
    int n;
    scanf("%d", &n);
    
    // 创建一个结构体数组来保存生肖和个数
    struct ZodiacCount zodiacCounts[NUM_ZODIACS];
    
    // 初始化结构体数组
    for (int i = 0; i < NUM_ZODIACS; i++) {
        zodiacCounts[i].zodiac = zodiacs[i];
        zodiacCounts[i].count = 0;
    }
    
    // 统计生肖个数
    char name[100], zodiac[100];
    for (int i = 0; i < n; i++) {
        scanf("%s %s", name, zodiac);
        for (int j = 0; j < NUM_ZODIACS; j++) {
            if (strcmp(zodiac, zodiacs[j]) == 0) {
                zodiacCounts[j].count++;
                break;
            }
        }
    }
    
    // 排序
    qsort(zodiacCounts, NUM_ZODIACS, sizeof(struct ZodiacCount), compareZodiac);
    
    // 输出结果
    for (int i = 0; i < NUM_ZODIACS; i++) {
        if (zodiacCounts[i].count > 0) {
            printf("%s %d\n", zodiacCounts[i].zodiac, zodiacCounts[i].count);
        }
    }
    
    return 0;
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
c语言编写万年历 #include <stdio.h> int main(int argc, char *argv[]) { int year,day,month,i,k,j; char ch; do{ printf("请输入一个年份year="); scanf("%d",&year); if(year<2010)//已知2010为虎年,把它作为相对年份 { j=(2010-year)%12;//12代表十二生肖 switch(j) { case 0: printf("\t\t\t虎年\n\n");break; case 1: printf("\t\t\t牛年\n\n");break; case 2: printf("\t\t\t鼠年\n\n");break; case 3: printf("\t\t\t猪年\n\n");break; case 4: printf("\t\t\t狗年\n\n");break; case 5: printf("\t\t\t鸡年\n\n");break; case 6: printf("\t\t\t猴年\n\n");break; case 7: printf("\t\t\t羊年\n\n");break; case 8: printf("\t\t\t马年\n\n");break; case 9: printf("\t\t\t蛇年\n\n");break; case 10: printf("\t\t\t龙年\n\n");break; case 11: printf("\t\t\t兔年\n\n");break; } } if(year>=2010)//若year小于0,则作为公元前 { j=(year-2010)%12; switch(j) { case 0: printf("\t\t\t虎年\n\n");break; case 1: printf("\t\t\t兔年\n\n");break; case 2: printf("\t\t\t龙年\n\n");break; case 3: printf("\t\t\t蛇年\n\n");break; case 4: printf("\t\t\t马年\n\n");break; case 5: printf("\t\t\t羊年\n\n");break; case 6: printf("\t\t\t猴年\n\n");break; case 7: printf("\t\t\t鸡年\n\n");break; case 8: printf("\t\t\t狗年\n\n");break; case 9: printf("\t\t\t猪年\n\n");break; case 10: printf("\t\t\t鼠年\n\n");break; case 11: printf("\t\t\t牛年\n\n");break; } } for(month=1;month<=12;month++) { switch(month) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: printf("%d月\t\t\t%d\n\n",month,year); printf("SUN\tMON\tTUE\tWEN\tTHU\tFRI\tSAT\n"); day=((year-1)*365+(year-1)/4-(year-1)/100+(year-1)/400+1)%7; //计算上一年12月31日的公式 k=(day+7)%7;//求该年1月1日是星期几 for(i=1;i<=k;i++) printf("\t");//打印每月1日之前的空格 for(i=1;i<=31;i++) { printf("%d\t",i); k++; if(k%7==0)//每行打印7个 printf("\n"); } printf("\n\n"); break; case 4: case 6: case 9: case 11: printf("%d月\t\t\t%d\n\n",month,year); printf("SUN\tMON\tTUE\tWEN\tTHU\tFRI\tSAT\n"); k=(day+7)%7; for(i=1;i<=k;i++) printf("\t"); for(i=1;i<=30;i++) { printf("%d\t",i); k++; if(k%7==0) printf("\n"); } printf("\n\n"); break; case 2: printf("%d月\t\t\t%d\n\n",month,year); printf("SUN\tMON\tTUE\tWEN\tTHU\tFRI\tSAT\n"); k=(day+7)%7; for(i=1;i<=k;i++) printf("\t"); if(year%4==0&&year%100!=0||year%400==0)//判断闰年 { for(i=1;i<=29;i++) { printf("%d\t",i); k++; if(k%7==0) printf("\n"); } printf("\n\n"); break; } else { for(i=1;i<=28;i++) { printf("%d\t",i); k++; if(k%7==0) printf("\n"); } printf("\n\n"); break; } } } printf("是否继续(Y/N)"); getchar(); ch=getchar(); }while(ch=='y'||ch=='Y');//是否继续输出另一年 return 0; }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

THK-J

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值