咖啡


私信TA

用户名:Tianxn

访问量:138181

签 名:

十年OI一场空,不开LL见祖宗。

等  级
排  名 10
经  验 27308
参赛次数 10
文章发表 197
年  龄 22
在职情况 学生
学  校 西安电子科技大学
专  业 软件工程

  自我简介:

解题思路:

首先我们初始化数组,从下标1开始吧;因为要求是从2开始的;具体赋值看我的代码很简单;

其次就是处理:加入n,m和题述代表的一样,我们遍历1到n;每次递增m个(而不是i++)即i += m;也就是一次处理一组数据,在创建一个内层循环,来求k个数的和sum,(注意我说的是k),k代表累加了多少个数,最后打印sum/k;这里不能除m因为不一定每次都是m个数,比如最后剩下1个,再去除m那就gg了;

这里还有一个细节,就是内层循环的判断条件j<m && i+j <= n ; j < m是为了每次加m个数的和, i+j<=n;是防止最后一次累加剩下的数不够m个,导致越界出错;总之大家可以仔细的看看;自己跟着程序走走,自然就明白了。


                        还有不懂得留言,谢谢……


注意事项:

参考代码:

#include <stdio.h>
#include <cstdlib>
#include <iostream>
#include <cmath>
#include <cstring>
#include <string>
#include <algorithm>
#include <functional>
using namespace std;
int main()
{
	int a[101];
	for(int i = 1; i < 101; ++i)
	{
		a[i] = 2*i;
	}
	int n, m;
	while(scanf("%d%d", &n, &m) != EOF)
	{
		for(int i = 1; i <= n; i += m)
		{
			int sum = 0, k = 0;
			for(int j = 0; j < m && i+j <= n; ++j)
			{
				sum += a[i+j];
				k++;
			}
			printf("%d ", sum/k);
		}
		printf("\n"); 
	} 
	return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »