Problem - D - Codeforces

Problem - D - Codeforces

这道题我们每次要选择一个长度大于等于k的区间,删除第k小元素,那么显然,对于整个数组的第1到第k-1小的元素,一定不会被删除,因为他们不会是任何一个子数组的第k小,因此只要不是这些数字,我们都可以删除,删除后,我们用双指针维护两端 ,如果相同就左右向中间移动,如果不同,如果其中一个是第k小的元素,那么我么那就删除 直到结束或者没有删除次数

代码实现如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long 
void solve(){
    int n,k;
    cin>>n>>k;
    vector<int>a(n+1,0);
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    vector<int>b=a;
    sort(b.begin()+1,b.end());
    int line=b[k-1];
    vector<int>ans;
    for(int i=1;i<=n;i++){
        if(a[i]<=line)ans.push_back(a[i]);
    }
    int sz=ans.size();
    int num=ans.size()-(k-1);
    int l=0,r=sz-1;
    while(l<r){
        if(ans[l]==ans[r]){
            l++,r--;
        }else {
            if(num&&ans[l]==line){
                l++,num--;
            }else if(num&&ans[r]==line){
                r--,num--;
            }else {
                cout<<"No\n";
                return ;
            }
        }
    }
    cout<<"YES\n";
}
signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    cin>>t;
    while(t--)solve();
    return 0;
}
相关推荐
陆水A9 分钟前
运输时效预测模型:静态路由时效的计算与验证
大数据·人工智能·算法·spark·数据库开发·etl工程师
电科一班林耿超11 分钟前
机器学习大师课 第 6 课:随机森林 —— 工业界最能打的 “万能算法“
算法·随机森林·机器学习
驼同学.13 分钟前
【求职季】LeetCode Hot 100 渐进式扫盲手册(Python版)
python·算法·leetcode
宵时待雨39 分钟前
优选算法专题6:模拟
数据结构·c++·算法·leetcode·职场和发展
Liangwei Lin44 分钟前
LeetCode 35. 搜索插入位置
数据结构·算法·leetcode
数智工坊1 小时前
【经典RL算法】Q-Learning:强化学习的里程碑——从理论到收敛证明的完整解析
论文阅读·人工智能·深度学习·算法·transformer
叼烟扛炮1 小时前
C++ 知识点19 匿名对象
开发语言·c++·算法·匿名对象
叼烟扛炮1 小时前
C++ 知识点23 类模板
开发语言·c++·算法·类模版
djarmy1 小时前
C 标准库 `<stdio.h>` 完整函数清单(官方标准 + 常用全部函数)
c语言·c++·算法
七牛云行业应用1 小时前
NotebookLM 手机版上线了,这份完整指南帮你把它用起来
算法