【题解】AB33 相差不超过k的最多数(排序 + 滑动窗口)

https://www.nowcoder.com/practice/562630ca90ac40ce89443c91060574c6?tpId=308&tqId=40490&ru=/exam/oj

排序 + 滑动窗口

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int main() {
    int n, k;
    cin >> n >> k;
    vector<int> v(n);
    for (int i = 0; i < n; ++i) {
        cin >> v[i];
    }
    sort(v.begin(), v.end());

    // 滑动窗口
    int ret = 0;
    for (int left=0, right=1; right < n; ++right) {
        while(v[right] - v[left] > k) {
            ++left;
        }
        int len = right - left + 1;
        if (ret < len) ret = len;
    }
    cout << ret << endl;

    return 0;
}
相关推荐
@卞7 分钟前
高阶数据结构 --- 单调队列
数据结构·c++·算法
星光一影20 分钟前
基于PHP+MySQL+Uniapp的上门家政服务系统源码
开发语言·mysql·uni-app·php
Antonio91521 分钟前
【Swift】 UIKit:UIGestureRecognizer和UIView Animation
开发语言·ios·swift
D***t13126 分钟前
PHP在API开发中的框架选择
开发语言·php
H***997626 分钟前
Java虚拟现实案例
java·开发语言·vr
Tan_Ying_Y38 分钟前
synchronized和ReentrantLock的区别是什么?他们的底层原理是什么?
开发语言·c#
ChineHe44 分钟前
Golang并发编程篇002_Go并发基础
开发语言·后端·golang
默恋~微凉1 小时前
shell(八)——WEB与Nginx
开发语言·前端·php
fpcc1 小时前
并行编程实战——CUDA编程的流的优先级
c++·cuda
lsx2024061 小时前
Go 语言类型转换
开发语言