候选人
题目描述
完成一个对候选人得票的统计程序。假设有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
这道超出我预估范围的小破题,太破了,做完感觉心里好赌,窒息,自动文字土拨鼠叫;啊~
题目给出用结构体,循环找相同名字,判断两个字符数组是否相同:
strcmp(charch1,charch2)==0<=>相同,否则,不同;(๑•̀ㅂ•́)و✧👍
#include <bits/stdc++.h>
using namespace std;
struct Person
{
char name[20];
int count;
} person[3]={"Li",0,"Zhang",0,"Fun",0};
int main() {
int n;
int k=3;//三个人,循环三次
scanf("%d",&n);
char ch[20];
while(n--)
{
scanf("%s",ch);
for(int j=0;j<k;++j)
{
if(!strcmp(ch,person[j].name))//判断两个字符数组是否相同
{
person[j].count++;//一样就加一
break;
}
}
}
for(int i=0;i<k;++i)
{
printf("%s:%d\n",person[i].name,person[i].count);
}
return 0;
}