剑指 Offer II 041. 滑动窗口的平均值
窗口 II Offer 滑动 平均值
2023-09-27 14:26:25 时间
给定一个整数数据流和一个窗口大小,根据该滑动窗口的大小,计算滑动窗口里所有数字的平均值。
实现 MovingAverage 类:
MovingAverage(int size) 用窗口大小 size 初始化对象。
double next(int val) 成员函数 next 每次调用的时候都会往滑动窗口增加一个整数,请计算并返回数据流中最后 size 个值的移动平均值,即滑动窗口里所有数字的平均值。
示例:
输入:
inputs = ["MovingAverage", "next", "next", "next", "next"]
inputs = [[3], [1], [10], [3], [5]]
输出:
[null, 1.0, 5.5, 4.66667, 6.0]
解释:
MovingAverage movingAverage = new MovingAverage(3);
movingAverage.next(1); // 返回 1.0 = 1 / 1
movingAverage.next(10); // 返回 5.5 = (1 + 10) / 2
movingAverage.next(3); // 返回 4.66667 = (1 + 10 + 3) / 3
movingAverage.next(5); // 返回 6.0 = (10 + 3 + 5) / 3
提示:
1 <= size <= 1000
-105 <= val <= 105
最多调用 next 方法 104 次
class MovingAverage {
vector<int> arr;
int s, sum;
int idx;
public:
/** Initialize your data structure here. */
MovingAverage(int size) {
s = size;
idx = 0;
sum = 0;
}
double next(int val) {
arr.push_back(val);
sum += val;
if (arr.size() > s) {
sum -= arr[idx++];
}
return sum * 1.0 / (arr.size() - idx);
}
};
/**
* Your MovingAverage object will be instantiated and called as such:
* MovingAverage* obj = new MovingAverage(size);
* double param_1 = obj->next(val);
*/
相关文章
- 【LeetCode】至少有 K 个重复字符的最长子串 [M](滑动窗口)
- eclipse:Console窗口不停的输出日志,导致操作失去焦点。
- js 调用父窗口的方法
- 关闭窗口即关闭程序_Java项目不挂断运行,即当账户退出或终端关闭时,程序仍然运行,并附上执行脚本.
- 使用Python,OpenCV给原视频每一帧画面添加素描漫画版小窗口,并生成新视频
- VC++进行窗口枚举
- iframe学习(一)之 窗口交互
- 【Java AWT 图形界面编程】设置窗口图标 ( IntelliJ IDEA 的图标资源位置 | 代码实现 | exe4j 设置导出 exe 程序对应的图标资源位置 )
- 关于HGE渲染窗口作为子窗口时无法得到窗口消息的问题以及解决办法
- vim的窗口切换
- halcon-dev_open_window_fit_image打开具有给定最小和最大范围的新图形窗口
- Flink Window那些事——窗口函数
- 【滑动窗口】剑指 Offer II 014. 字符串中的变位词
- 双缓冲绘图和窗口控件的绘制——ATL ActiveX 窗口控件生成向导绘制代码OnDraw的一个错误 .