解题思路:
首先我们初始化数组,从下标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 人评分