完成一个对候选人得票的统计程序。假设有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每人的得票数。格式为首先输出人名,其后输出一个冒号,最后输出候选人的得票数。 请注意行尾输出换行。
10 Li Li Fun Zhang Zhang Fun Li Fun Zhang Li
Li:4 Zhang:3 Fun:3
#include<stdio.h> #include<cstring> struct persion{ char name[20]; int count; }leader[3] = {"Li",0,"Zhang",0,"Fun",0}; int main() { int n; struct persion p; scanf("%d",&n); for(int i =0; i < n; i++ ){ scanf("%s",p.name); if(strcmp(p.name,leader[0].name)==0){ leader[0].count++; } if(strcmp(p.name,leader[1].name)==0){ leader[1].count++; } if(strcmp(p.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; }