候选人

候选人

题目描述

完成一个对候选人得票的统计程序。假设有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;
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值