算法笔记 结构体 问题 A: C语言11.1

题目描述

完成一个对候选人得票的统计程序。假设有3个候选人,名字分别为Li,Zhang和Fun。使用结构体存储每一个候选人的名字和得票数。记录每一张选票的得票人名,输出每个候选人最终的得票数。结构体可以定义成如下的格式:
struct person {
char name[20];
int count; }leader[3] = {“Li”, 0, “Zhang”, 0, “Fun”, 0};

输入

第一行有一个整数n,表示以下有n张选票信息将会输入。保证n不大于100。
以后的n行中,每一行包含一个人名,为选票的得票人。保证每一个人名都是Li,Zhang和Fun中的某一个。

输出

有三行,分别为Li,Zhang和Fun每人的得票数。格式为首先输出人名,其后输出一个冒号,最后输出候选人的得票数。 请注意行尾输出换行。

样例输入 Copy

10
Li
Li
Fun
Zhang
Zhang
Fun
Li
Fun
Zhang
Li

样例输出 Copy

Li:4
Zhang:3
Fun:3

#include
#include

struct person {
    char name[20];
    int count;
}Leader[3] = {"Li", 0, "Zhang", 0, "Fun", 0};

int main() {
    int n;
    char name[20];
    scanf("%d", &n);
    if(n>100) return 0;
    for(int i = 0, j = 0; i < n; i++) {
        scanf("%s", name);
        if(strcmp(name,Leader[0].name)==0) Leader[0].count++;
        if(strcmp(name,Leader[1].name)==0) Leader[1].count++;
        if(strcmp(name,Leader[2].name)==0) Leader[2].count++;
    }

    for(int i = 0; i < 3; i++) {
        printf("%s:%d\n", Leader[i].name, Leader[i].count);
    }

    return 0;
}

你可能感兴趣的:(算法笔记,算法,c语言,c++,数据结构)