GitHub


问题描述

5-3 计算平均值 (50分)

现在为若干组整数分别计算平均值。

已知这些整数的绝对值都小于100,每组整数的数量不少于1个,不大于20个。

输入格式:首先输入K(不小于2,不大于20)。接下来每一行输入一组数据(至少有一组数据),每组至少有一个数据,在有多个数据时,两个数据之间有1到3个空格。最后一行输入100,标志输入的结束。

输出格式:对于每一组数据,输出其前K个数据的均值,如果该组数据个数少于K时,则输出该组所有数据的均值。输出的均值只输出整数部分,直接忽略小数部分。

样例输入:

3

10 30 20 40

-10 17 10

10 9

100

样例输出:

20

5

9

时间限制:400ms

内存限制:64MB

代码长度限制:16kB

判题程序:系统默认

作者:east

单位:福州大学


解题思路

因为数据很小,所以不需要做什么优化。

其实题目的重点就在于如何读入数据以及如何将读入的数据处理成令人愉悦的形式,另外还有一些需要注意的小地方,如负数的判断均值个数的判断等。

关于如何读入数据,可以用gets或fgets将数据作为字符串整行读进来,要注意的是以下第一个数据K后的回车也会被读入,所以要多读一次。不过因为gets不太安全,所以新标准C11中把它抛弃了。。VS中gets被预处理为gets_s,用法为gets_s(变量名,size)。或者改用fgets也可以。fgets用法为fgets(变量名,size,文件),如果是控制台中的,文件就用stdin。

关于如何处理读入的数据,其实处理字符串的问题平时就经常碰到,而且这次的计算器中也有类似的,就是在栈运算中要把表达式的数字单独挑出来。我用的方法,是在判断当当前字符的ASCLL码值介于'0'与'9'之间时,进行循环累加,部分代码如下:

while ((c[i] >= '0') && (c[i] <= '9'))
{
t = 10 * t + c[i] - '0';
i++;
}

关于负数的判断,其实不需要对负数和正数进行分类,只要设置一个初始值为1的变量,在进入数字判时,对其前一位的符号进行判断。如果是负数,则将变量值设为-1,否则不变,最后再与筛出来的数相乘就行。

还有就是需要求均值的个数要注意一下。


代码

#include<iostream>
#include<cstring>
using namespace std; int main()
{
int i, j, k, n, m, s, t, a[30];
char c[1000];
cin >> n;
fgets(c, 1000, stdin);
while (1 > 0)
{
fgets(c, 1000, stdin);
j = -1;
i = 0;
while (i < strlen(c))
{
if ((c[i] >= '0') && (c[i] <= '9'))
{
m = 1;
if (c[i - 1] == '-') m = -1;
t = 0;
while ((c[i] >= '0') && (c[i] <= '9'))
{
t = 10 * t + c[i] - '0';
i++;
}
j++;
a[j] = t*m;
}
i++;
}
if ((j == 0) && (a[0] == 100)) break;
j++;
s = 0;
if (j > n)
{
for (i = 0; i < n; i++)
s += a[i];
cout << s / n << endl;
}
else
{
for (i = 0; i < j; i++)
s += a[i];
cout << s / j << endl;
}
}
return 0;
}

如果还有其他需要,那再补充。

PTA 5-3 解题报告的更多相关文章

  1. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  2. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  5. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  6. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  7. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  8. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  9. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

  10. ACM: Just a Hook 解题报告 -线段树

    E - Just a Hook Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u   D ...

随机推荐

  1. Vue+restfulframework示例

    一.简单回顾vue 前不久我们已经了解了vue前端框架,所以现在强调几点: 修改源: npm config set registry https://registry.npm.taobao.org 创 ...

  2. 【mysql】编码问题

    原始数据是unicode,存入数据库.需要注意的几个地方: 1.建立数据库时,选择编码方式为utf8 -- UTF-8 Unicode 2.代码中建立数据库连接时,选择charset=utf8 3.存 ...

  3. Visual Studio UML类图

    1.unified Modeling Language(UML)称为同一建模语言或者标准建语言, 用例图:对系统的使用方式的分类.类图:显示类和他们的相互关系.  对象图:只显示对象及他们的相互关系. ...

  4. HTML&javaSkcript&CSS&jQuery&ajax(三)

    一.HTML块元素 1.块级元素 Block level element ,内联元素 inline element , HTML<div>元素属于块级元素,他是组合其他HTML元素的容器, ...

  5. appium获取APP控件信息

    uiautomatorviewer.bat 该文件位于SDK安装目录tools下,如笔者在“C:\Program Files (x86)\Android\android-sdk\tools”下,双击u ...

  6. 关于C++ const 的全面总结 (转)

    C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根据各方面查到的资料进行总结如下,期望对朋友们有所帮助. Const 是C++中常用的类型修饰符,常类型是指使用类 ...

  7. fetch请求

    get请求 return fetch('https://xxx.xxx.com/xxx.json') .then(response => response.json()) .then(respo ...

  8. mac下安装Brew 警告:Warning: /usr/local/bin is not in your PATH.

    终端输入命令 export PATH=/usr/local/bin:$PATH

  9. SqlServer 分页存储过程

    SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE PROCEDURE [dbo].[usp_CommonDataResourcePaged ...

  10. SpringBoot学习(3)-SpringBoot添加支持CORS跨域访问

    SpringBoot学习(3)-SpringBoot添加支持CORS跨域访问 https://blog.csdn.net/yft_android/article/details/80307672