当前位置: 首页 > article >正文

G1. Yunli‘s Subarray Queries (easy version)

题目链接:Problem - 2009G1 - Codeforces

题目大意: 给你一个长度为n的整数数组a序列, 然后你可以操作任何次, 将序列里的一个数换成其他任意数字。 后有q次询问, 每一次询问[L, R] 在此区间里, 可最少进行多少次以上操作, 让[L, R] 成为一个连续的子数组。

输入:

第一行包含 t ( 1≤t≤1e4 ) - 测试用例数。

每个测试用例的第一行包含三个整数 n 、 k 和 q ( 1≤k≤n≤2⋅1e5 , 1 ≤ q ≤ 2⋅1e5 )--数组长度、连续子数组长度和查询次数。

下面一行包含 n 个整数 a1,a2,…,an ( 1 ≤ ai ≤ n )。

下面 q 行包含两个整数 l 和 r ( 1≤ l ≤ r ≤ n , r=l+k−1 )--查询的边界。

保证所有测试用例中 n 的总和不超过 2⋅1e5 ,所有测试用例中 q 的总和不超过 2⋅1e5 。

在此版本中保证r = l + k - 1.

考察:                                      滑动窗口,  c++STL,  离线查询

1. 技巧, 让我们求[l,r] 区间了的数变成连续的数,的最少操作次数。如果采用滑动窗口, 可以发现,在k长的窗口内, 不好统计连续的子数组。 此时  采用  该数 减 该数的下标, 后统计在窗口内的众数(即:a[ i ] - i), 这样让求法可以进行。  假如: 1 2 3 5 变换过后 0 0 0 1, 这样连续的子数组就为此时0的个数。

2. 采用map, multiset, 来维护窗口的数据,map记录窗口里数据的出现次数, multiset记录出现次数的排序, 每一次的众数的数量 为 *st.rbegin(). 

3.离线查询: 通过以上窗口的滑动, 记录每一个区间的某一个数的最大数量。最后输出即可。

#include <bits/stdc++.h>
using namespace std;

using i64 = long long;
using i128 = __int128;
using ui64 = unsigned long long;

void solve(){
    int n, k, q;
    cin >> n >> k >> q;
    vector<int> a(n+1);
    for(int i=1; i<=n; i++) {
        cin >> a[i];
    }
    //离线查询时用的mp
    map<pair<int,int>, int> mp;
    map<int, int> cnt;
    multiset<int> st;
    int l=1, r=1;
    
    while(r<=n) {
        int num = cnt[a[r]-r]++;//进入窗口
        st.insert(num+1);
        auto it = st.find(num);
        if(it!=st.end()) {
            st.erase(it);
        }
        if(r - l == k-1) {//等于窗口大小时,更新ans, l同时移动
            mp[{l,r}] = *st.rbegin();
            num = cnt[a[l]-l]--;
            st.insert(num-1);
            it = st.find(num);
            if(it != st.end()) {
                st.erase(it);
            }//滑出窗口的操作
            l++;
        }
        r++;
    }
    while(q--) {
        int l, r;
        cin >> l >> r;
        cout << k - mp[make_pair(l, r)] << "\n";
    }
}
int main(){
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);
    int t = 1;
    cin >> t;
    while(t--) {
        solve();
    }
    return 0;
}

感谢你的收看与点赞, 欢迎大佬指正。


http://www.kler.cn/a/531910.html

相关文章:

  • 【Redis】安装配置Redis超详细教程 / Linux版
  • 【C++篇】位图与布隆过滤器
  • ubuntu磁盘扩容
  • AP单类平均准确率
  • 自学习记录-编程语言的特点(持续记录)
  • nodejs:js-mdict 的下载、安装、测试、build
  • Java 大视界 -- Java 大数据在智能电网中的应用与发展趋势(71)
  • 2月3日星期一今日早报简报微语报早读
  • 遭受大量境外网络攻击,郭盛华公开发声支持DeepSeek
  • 基于Spring Security 6的OAuth2 系列之十 - 授权服务器--刷新token
  • 优化代码性能:利用CPU缓存原理
  • 人工智能学习(五)之机器学习逻辑回归算法
  • DeepSeek-R1 本地部署教程(超简版)
  • SwiftUI 在 Xcode 预览修改视图 FetchedResults 对象的属性时为什么会崩溃?
  • DRM系列七:Drm之CREATE_DUMB
  • C++(进阶) 第8章unordered_map和unordered_set的使⽤(哈希)
  • 基于STM32景区环境监测系统的设计与实现(论文+源码)
  • 分布式数据库架构与实践:原理、设计与优化
  • 3 卷积神经网络CNN
  • ES6 入门教程:箭头函数、解构赋值及其他新特性详解
  • Gurobi求解旅行商问题的官方例程
  • 计网week3
  • 【LeetCode 刷题】回溯算法(5)-棋盘问题
  • Linux线程 —— 生产消费模型
  • 存储器知识点3
  • 优选算法的灵动之章:双指针专题(一)