【PTA】猜数字

L1-056 猜数字 (20分)

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

输入格式:

输入在第一行给出一个正整数N(104)。随后 N 行,每行给出一个玩家的名字(由不超过8个英文字母组成的字符串)和其猜的正整数(≤ 100)。

输出格式:

在一行中顺序输出:大家平均数的一半(只输出整数部分)、赢家的名字,其间以空格分隔。题目保证赢家是唯一的。

输入样例:

7
Bob 35
Amy 28
James 98
Alice 11
Jack 45
Smith 33
Chris 62

输出样例:

22 Amy

首先考虑到的是结构体Player来存储参加该游戏(猜数字)的玩家。
然后呢,这些玩家有姓名用string字符串类型存储,还有进行游戏的数字100以内用整型int存储。
获胜条件是接近平均数的一半,一开始我想的是四舍五入和小数上的问题,本来是想之后改进。
在看到输入样例和输出样例,22 Amy的时候,用计算器算了一下,原本是小数的22变成了整数22。
所以一直就用整型运算。
首先是结构体
typedef struct player
{
    int guess;
    string name;
    int num;
}Player;
然后是num是玩家猜的数与平均数差的绝对值,其值用abs()函数在自带的cmath库。
源代码是:
#include <iostream>
#include <cmath>
using namespace std;

typedef struct player//定义结构体Player
{
    int guess; //玩家进行猜数的数字
    string name; //玩家姓名
    int num; //玩家猜的数字与平均数的一半差的绝对值
}Player;

int main()
{
    int n;//玩家数量
    cin >> n;
    int sum=0;//猜数之和
    int average;//猜数平均数的一半
    Player player[10000];
    for (int i = 0; i < n; i++)
    {
        cin >> player[i].name;
        cin >> player[i].guess;
        sum += player[i].guess;
    }//录入信息
    average = sum / (2*n);
    for (int i = 0; i < n; i++)
    {
        player[i].num = abs(average - player[i].guess);//计算num
    }
    int min = 0;
    for (int i = 0; i < n; i++)
    {
        if (player[i].num < player[min].num) min = i;//求最小的num玩家下标,标记为min
    }
    cout << average << " " << player[min].name;//输出

}


猜你喜欢

转载自www.cnblogs.com/Andre/p/12193678.html