题目描述:
完成一个对候选人得票的统计程序。假设有3个候选人,名字分别为Li,Zhang和Fun。使用结构体存储每一个候选人的名字和得票数。记录每一张选票的得票人名,输出每个候选人最终的得票数。结构体可以定义成如下的格式:
1 2 3 4
| 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
train of thought:
code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| #include <cstdio> #include <cstring> struct person { char name[20]; int count; } leader[3] = {"Li", 0, "Zhang", 0, "Fun", 0}; int main() { int n; char a[20]; scanf("%d", &n); for (int i = 0; i < n; i++) { scanf("%s", a); if (strcmp(a, leader[0].name) == 0) { leader[0].count++; } else if (strcmp(a, leader[1].name) == 0) { leader[1].count++; } else { leader[2].count++; } } for (int i = 0; i < 3; i++) { printf("%s:%d\n", leader[i].name, leader[i].count); } return 0; }
|