问题 A: C语言11.1

问题 A: C语言11.1

时间限制: 1 Sec  内存限制: 32 MB
献花: 265  解决: 228
[献花][花圈][TK题库]

题目描述

完成一个对候选人得票的统计程序。假设有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<string >

 
 

#include<iostream>

 
 

using namespace std;

 
 

struct person{                //结构体数组的初始化

 
 

         char name[20];

 
 

         int count;

 
 

}leader[3]={"Li", 0, "Zhang", 0, "Fun", 0};

 
 

 

 
 

int main(){

 
 

         int n;

 
 

         string temp;

 
 

         scanf("%d",&n);

 
 

         for(int i=0;i<n;i++){

 
 

                   cin>>temp;

 
 

                   if(temp==leader[0].name){

 
 

                            leader[0].count++;

 
 

                   }

 
 

                   if(temp==leader[1].name){

 
 

                            leader[1].count++;

 
 

                   }

 
 

                   if(temp==leader[2].name){

 
 

                            leader[2].count++;

 
 

                   }

 
 

         }

 
 

                  

 
 

         printf("Li:%d\n",leader[0].count);

 
 

         printf("Zhang:%d\n",leader[1].count);

 
 

         printf("Fun:%d\n",leader[2].count);

 
 

         return 0;

 
 

}

 

转载于:https://www.cnblogs.com/zhhjthing/p/7845877.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值