算法笔记 练习 11.1

题目描述
完成一个对候选人得票的统计程序。假设有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<iostream>
#include<cstring>
using namespace std;

struct person{
 char name[20];
 int count;
}leader[3] = {"Li",0,"Zhang",0,"Fun",0};

int main(){
 int n;
 scanf("%d",&n);
 getchar();//吸收掉scanf末尾的换行符 
 char s[n][20];
 
 for(int i = 0;i < n;i++){
  gets(s[i]);
  if(strcmp(s[i],leader[0].name) == 0){//不能直接写if(s[i]==leader[0].name,无法比较 
   leader[0].count++;
  }
  else if(strcmp(s[i],leader[1].name) == 0){
   leader[1].count++;
  }
  else{
   leader[2].count++;
  }
 }
 for(int i = 0;i < 3;i++){
  printf("%s:%d\n",leader[i].name,leader[i].count);
 }
 return 0;
} 

11.8
题目描述
有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩。读入这10个学生的数据,要求输出3门课程的总平均成绩,以及个人平均分最高的学生的数据(包括学号、姓名、3门课程成绩、平均分数)。
输入
共有10行,每行包含了一个学生的学号(整数)、名字(长度不超过19的无空格字符串)和3门课程的成绩(0至100之间的整数),用空格隔开。
输出
第一行包含了3个实数,分别表示3门课程的总平均成绩,保留2位小数,每个数之后输出一个空格。

第二行输出个人平均分最高的学生的数据,与输入数据格式相同。如果有多位个人平均分最高的学生,输出按照输入顺序第一个最高分的学生数据。

请注意行尾输出换行。
样例输入
101 AAA 80 81 82
102 BBB 83 84 85
103 CCC 86 87 88
104 DDD 89 90 91
105 EEE 92 93 94
106 FFF 80 90 100
107 GGG 85 90 95
108 HHH 80 85 90
109 III 90 91 92
110 JJJ 91 88 87
样例输出
85.60 87.90 90.40
105 EEE 92 93 94
代码描述:

#include<iostream>
#include<cstring>
using namespace std;

struct student{
 int num;
 char name[20];
 int sorce1;
 int score2;
 int socre3;//为什么不能设置为socre[3],调用stu[i].score[i]???
}stu[10];
void cal(){
 double val[3]={};
 int ave[10]={};
 int max = ave[0];
 for(int i = 0;i < 10;i++){
  scanf("%d%s%d%d%d",&stu[i].num,&stu[i].name,&stu[i].sorce1,&stu[i].score2,&stu[i].socre3);
 }
 for(int i = 0;i < 10;i++){
  ave[i] = stu[i].sorce1 + stu[i].score2 + stu[i].socre3;
  ave[i] /= 3;
  if(max < ave[i]){
   max = ave[i];
  }
  val[0] += stu[i].sorce1;
  val[1] += stu[i].score2;
  val[2] += stu[i].socre3;
 }
 printf("%.2f %.2f %.2f\n",val[0]/10,val[1]/10,val[2]/10);
 for(int i = 0;i < 10;i++){
  if(ave[i] == max){
   printf("%d %s %d %d %d",stu[i].num,stu[i].name,stu[i].sorce1,stu[i].score2,stu[i].socre3);
  }
 }
}
int main(){
 cal();
 return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值