一、问题描述
猜数字
一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。
二、流程设计
- 定义people结构体,包含姓名和报数;
- 录入的同时计算总数;
- 计算平均数/2,输出其整数部分;
- 遍历寻找绝对值最小的人,输出名字。
三、代码实现
#include <iostream>
#include <cmath>
using namespace std;
struct people
{
string name;//姓名
int num;//猜的数字
};
int main()
{
int n;//录入n个人
cin>>n;
struct people p[n];//用于记录所有信息
int sum=0;//记录总数
for(int i=0;i<n;i++)//录入并计算总数
{
cin>>p[i].name>>p[i].num;
sum+=p[i].num;
}
double ave=(double)sum/(2*n);//计算平均值/2
cout<<floor(ave)<<' ';//输出平均值的整数部分
string s;//记录赢家姓名
double cz=9999999;//差值
for(int i=0;i<n;i++)//遍历找到绝对值最小的
{
if(fabs(p[i].num-ave)<cz)
{
s=p[i].name;
cz=fabs(p[i].num-ave);
}
}
cout<<s;
return 0;
}
标签:struct,people,int,sum,num,打卡,建民,4.26 From: https://www.cnblogs.com/cor0000/p/17357145.html