【算法笔记】Codeup 100000572A

本专栏仅仅用于个人记录刷题过程,如有更好的解决方法,可以留言哦

题目要求

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

样例

10
Li
Li
Fun
Zhang
Zhang
Fun
Li
Fun
Zhang
Li

要求输出

有三行,分别为Li,Zhang和Fun每人的得票数。格式为首先输出人名,其后输出一个冒号,最后输出候选人的得票数。
请注意行尾输出换行。
样例

Li:4
Zhang:3
Fun:3

可AC代码如下

#include<stdio.h>
#include<string.h>
struct person {
	char num[20];
	int count;
}leader[3] = {"Li", 0, "Zhang", 0, "Fun",0};
int main(){
	int n;
	char str[20];
	//输入n,n不大于0时才继续运行,否则结束程序 
	while(1){
		scanf("%d",&n);
		getchar();
		if(n <= 100){
			break;
		}else{
			return 0;
		}
	}
	//开始选举,只有输入正确了,对应票数才加一	
	for(int i = 0; i < n; i++){
		gets(str);
		if(strcmp(str, "Li") == 0){
			leader[0].count++;
		}else if(strcmp(str, "Zhang") == 0){
			leader[1].count++;
		}else if(strcmp(str, "Fun") ==0){
			leader[2].count++;
		}else{
			return 0;
		}	
	}
	//开始唱票 
	for(int i = 0; i < 3; i++){
		printf("%s:%d\n", leader[i].num, leader[i].count);
	}	
	return 0;
}

遇到的问题

  • 如果在scanf()和gets()之间不加getchar()接收回车的话,本程序将直接结束

总结

  • 输入输出缓冲区的内容自行搜索(先挖坑,日后填)
  • gets()接收空格,以回车结束
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值