【刷题】输入回车结束输入,统计一下每个歌手获得的票数。

题目:
学校推出了10名歌手,校学生会想知道这10名歌手受欢迎的程度,设了一个投票箱,让每一个同学给自己喜欢的歌手投票,为了方便,学生会把10个歌手用1~10进行编号,这样,同学们只要用编号进行投票了。现在,学生会找到你,帮助统计一下每个歌手获得的票数。

分析:
很直观的想法是,投谁,谁的票数加1。如:投2号,则2号的票数加1,投6号,6号的票数加1。如何表示这么一个操作过程呢?

设变量num[i]表示第i个歌手的票数,相当于用名称num表示票数,然后再对名称进行编号,编号为i的num表示第i个歌手的票数。

这样,投2号,则2号的票数加1,就可以表达为:
i=2;num[i]=num[i]+1
投6号,则6号的票数加1,就可以表达为:
i=6;num[i]=num[i]+1

归纳上述分析,具体实现步骤如下:
(1)开辟num[1]~num[10]变量分别存放10个歌手的票数。
(2)读入选票赋给i。
(3)对应选票i的歌手票数加1,即num[i]=num[i]+1。
(4)重复(2)和(3)的操作,直到读完选票为止。
(5)输出每位歌手的票数。

程序如下:

方法一:

#include<bits/stdc++.h>
using namespace std;
int main(){
	int num[11];
	int i;
	memset(num,0,sizeof(num));
	while(cin.peek()!='\n'){
		cin>>i;
		num[i]++;
	}
		
	for(i=1;i<=10;i++){
		cout<<num[i]<<endl;
	}
	return 0;
}

cin.peek() 是 C++ 标准库中的一个方法,用于从输入流(通常是键盘输入)中查看下一个字符,但不从输入流中删除它。这个方法主要用于在不实际消费字符的情况下预览或检测输入流中的下一个字符。

当你调用 cin.peek() 时,它会返回输入流中的下一个字符的 ASCII 值。如果输入流已经到达末尾(EOF),则 cin.peek() 会返回 EOF。

方法二:

#include<bits/stdc++.h>
using namespace std;
int main(){
	int num[11];
	int i;
	char s;
	memset(num,0,sizeof(num));
	while(cin>>i){
		s=getchar();           //s用来接收是否是回车
		num[i]++;
		if(s=='\n') break;
	}
		
	for(i=1;i<=10;i++){
		cout<<num[i]<<endl;
	}
	return 0;
}

getchar() 是 C 语言中的一个标准库函数,用于从标准输入(通常是键盘)读取一个字符,并返回该字符的 ASCII 值。这个函数是定义在 <stdio.h> 头文件中的。

当你调用 getchar() 时,它会等待用户输入一个字符,然后按下 Enter 键。一旦用户输入了字符并按下 Enter,getchar() 就会返回该字符的 ASCII 值。如果发生错误或达到文件末尾,getchar() 会返回 EOF(End Of File),通常是一个负值(在大多数系统上,EOF 的值是 -1)。

  • 11
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,这是一个关于统计候选人票数的问题,下面是 C 语言的实现代码: ```c #include <stdio.h> #include <string.h> #define MAX_NAME_LEN 20 // 候选人姓名最大长度 #define CANDIDATE_NUM 5 // 候选人数 // 候选人结构体 struct candidate { char name[MAX_NAME_LEN]; // 姓名 int votes; // 票数 }; int main() { // 初始化候选人信息 struct candidate candidates[CANDIDATE_NUM] = { {"candidate1", 0}, {"candidate2", 0}, {"candidate3", 0}, {"candidate4", 0}, {"candidate5", 0} }; // 统计候选人票数 char name[MAX_NAME_LEN]; printf("请输入候选人姓名(以#结束):\n"); while (scanf("%s", name) == 1 && name[0] != '#') { int i; for (i = 0; i < CANDIDATE_NUM; i++) { if (strcmp(name, candidates[i].name) == 0) { candidates[i].votes++; // 票数加1 break; } } if (i == CANDIDATE_NUM) { printf("未找到候选人 %s\n", name); } } // 输出候选人票数 int total_votes = 0; printf("候选人票数统计结果:\n"); for (int i = 0; i < CANDIDATE_NUM; i++) { printf("%s: %d 票\n", candidates[i].name, candidates[i].votes); total_votes += candidates[i].votes; } printf("总票数:%d\n", total_votes); return 0; } ``` 这段代码定义了一个 `candidate` 结构体来表示候选人的信息,包括姓名和票数。使用一个结构体数组来存储5个候选人的信息。在统计候选人票数时,使用一个循环来输入候选人的姓名,然后遍历候选人信息数组,查找候选人姓名是否匹配,如果匹配,则将对应候选人的票数加1。如果未匹配,则输出未找到候选人信息。最后,使用一个循环输出每个候选人的票数,并计算总票数输出。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

relizi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值