博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
L1-056 猜数字
阅读量:4685 次
发布时间:2019-06-09

本文共 1076 字,大约阅读时间需要 3 分钟。

L1-056 猜数字 (20 分)

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

输入格式:

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

输出格式:

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

输入样例:

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

输出样例:

22 Amy
#include
#include
#include
using namespace std;struct People { string name; int number;};int main() { People people[10000]; int n, target, tp = 0, sum = 0, min = 100000; cin >> n; for (int i = 0; i < n; i++) { cin >> people[i].name >> people[i].number; sum += people[i].number; } target = (sum / n) / 2; for (int i = 0; i < n; i++) { int d = abs(people[i].number - target); if (min > d) { min = d; tp = i; } } cout << target << " " << people[tp].name; return 0;}

初次提交的时候,因为min的值为0,导致程序没有办法更新min的值。在最后一个访问点出现段错误,所谓的段错误就是内存访问越界,经过检查,发现自己最开始的people数组定义为1000,小于题目所要求的。

转载于:https://www.cnblogs.com/Frances-CY-FKYM/p/10299517.html

你可能感兴趣的文章
浅谈 Java XML 底层解析方式
查看>>
ADO.NET介绍
查看>>
贪吃蛇easyx版本
查看>>
百度地图 JS API开发Demo01
查看>>
采用javascript实现WebGIS页面元素动态布局
查看>>
约瑟夫环问题
查看>>
Real-Time C++: Efficient Object-Oriented and Template Microcontroller Programming.pdf
查看>>
WPF 获取指定文件的Icon
查看>>
mysql实践(四)
查看>>
在linux服务器上配置anaconda和Tensorflow,并运行
查看>>
[POJ2823][洛谷P1886]滑动窗口 Sliding Window
查看>>
Flex 4.x 下载进度不出现问题解决办法
查看>>
Vue之自定义组件的v-model
查看>>
Vue项目碰到"‘webpack-dev-server’不是内部或外部命令,也不是可运行的程序或批处理文件"报错...
查看>>
解决Xcode在ipad/iphone 9.2 系统真机测试时出现could not find developer disk image问题
查看>>
基于asp.net的ajax分页
查看>>
分布式事务,两阶段提交协议,三阶段提交协议
查看>>
php/js获取客户端mac地址的实现代码
查看>>
float 在父元素为inline元素的情况
查看>>
git的基本使用
查看>>