建民打卡日记4.26

发布时间 2023-04-26 20:13:43作者: cor0000

一、问题描述

猜数字

一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。

二、流程设计

  1. 定义people结构体,包含姓名和报数;
  2. 录入的同时计算总数;
  3. 计算平均数/2,输出其整数部分;
  4. 遍历寻找绝对值最小的人,输出名字。

三、代码实现

#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;
}