算法笔记:结构体

算法笔记:结构体

题目一

完成一个对候选人得票的统计程序。假设有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每人的得票数。格式为首先输出人名,其后输出一个冒号,最后输出候选人的得票数。
请注意行尾输出换行。

代码

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

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);
	
	for(int i= 0;i< n ;i++){
		scanf("%s",name);
		for(int i =0;i<3;i++){
			if(strcmp(name,leader[i].name) == 0){ // 比较字符串
				leader[i].count += 1;
			}
		}
	}
	
	for(int i =0;i<3;i++){
		printf("%s:%d\n",leader[i].name,leader[i].count);
	}
	
	return 0;
}
上一篇:SpringBoot项目 Apollo配置的外置化


下一篇:靠谱的人都有什么特质,你是一个靠谱的人吗?