[CF1476G] Minimum Difference

Minimum Difference の 传送门

显然不同出现次数的数最多 \(O \left ( \sqrt n \right )\)

\(\sum\limits_{i=1}^k i = n\)

算出 \(k\) 最大为 \(\sqrt n\)

莫队 + 值域分块,维护每个出现次数有几个数。

查询时扫所有块,块内有值就暴力整块,把所有有值的位置提出来,做双指针。

具体一点,设当前双指针的左右端点分别为 \(l, r\)

不断循环直到 \(\left [ l, r \right ]\) 总的出现次数大于等于 \(k\)

然后每次把 \(l\) 往后移一位就行。

#include <bits/stdc++.h>
using namespace std;
inline int read()
{int f = 0, ans = 0;char c = getchar();while (!isdigit(c))f |= c == '-', c = getchar();while (isdigit(c))ans = (ans << 3) + (ans << 1) + c - 48, c = getchar();return f ? -ans : ans;
}
void write(int x)
{if (x < 0)putchar('-'), x = -x;if (x > 9)write(x / 10);putchar(x % 10 + '0');
}
constexpr int N = 1e5 + 5, V = 1e5, inf = 1e9;
int n, m, a[N], res[N];
int blk, l, r, bl[N], mp[N];
struct oper
{int p, lst, x;
} op[N];
struct quest
{int l, r, k, tim, id;bool operator<(const quest &rhs) const{if (bl[l] != bl[rhs.l])return l < rhs.l;if (bl[r] != bl[rhs.r])return r < rhs.r;return tim < rhs.tim;}
} q[N];
namespace block
{int blk, tot, bl[N], L[N], R[N];int t, s[N], cnt[N], cnt_blk[N];inline void init(){blk = pow(V, 2.0 / 3);tot = V / blk + (bool)(V % blk);for (int i = 1; i <= V; ++i)bl[i] = (i - 1) / blk + 1;for (int i = 1; i <= tot; ++i)L[i] = (i - 1) * blk + 1, R[i] = i * blk;R[tot] = V;}inline void modify(int x, int w) { x ? (cnt[x] += w, cnt_blk[bl[x]] += w) : 0; }inline int get_ans(int k){t = 0;for (int i = 1; i <= tot; ++i)if (cnt_blk[i])for (int j = L[i]; j <= R[i]; ++j)if (cnt[j])s[++t] = j;int ans = inf, sum = 0;for (int l = 1, r = 0; l <= t; ++l){while (r < t && sum < k)sum += cnt[s[++r]];if (sum < k)break;ans = min(ans, s[r] - s[l]);sum -= cnt[s[l]];}return ans;}
}
inline void init()
{block::init(), blk = pow(n, 2.0 / 3);for (int i = 1; i <= n; ++i)bl[i] = (i - 1) / blk + 1;
}
inline void insert(int x) { block::modify(mp[x], -1), block::modify(++mp[x], 1); }
inline void remove(int x) { block::modify(mp[x], -1), block::modify(--mp[x], 1); }
inline void insert_in_bound(int i)
{if (i >= l && i <= r)block::modify(mp[a[i]], -1), block::modify(++mp[a[i]], 1);
}
inline void remove_in_bound(int i)
{if (i >= l && i <= r)block::modify(mp[a[i]], -1), block::modify(--mp[a[i]], 1);
}
inline void forward(int i)
{auto &[p, lst, x] = op[i];remove_in_bound(p);a[p] = x;insert_in_bound(p);
}
inline void backward(int i)
{auto &[p, lst, x] = op[i];remove_in_bound(p);a[p] = lst;insert_in_bound(p);
}
signed main()
{// freopen("chk.in", "r", stdin);// freopen("chk.out", "w", stdout);n = read(), m = read();for (int i = 1; i <= n; ++i)a[i] = read();init();int que = 0, ti = 0;for (int i = 1; i <= m; ++i)if (read() == 1){++que, q[que] = {0, 0, 0, ti, que};q[que].l = read(), q[que].r = read(), q[que].k = read();}else{++ti;op[ti].lst = a[op[ti].p = read()];a[op[ti].p] = op[ti].x = read();}while (ti)a[op[ti].p] = op[ti].lst, --ti;sort(q + 1, q + que + 1);l = 1, r = 0;for (int i = 1; i <= que; ++i){while (l > q[i].l)insert(a[--l]);while (r < q[i].r)insert(a[++r]);while (l < q[i].l)remove(a[l++]);while (r > q[i].r)remove(a[r--]);while (ti < q[i].tim)forward(++ti);while (ti > q[i].tim)backward(ti--);res[q[i].id] = block::get_ans(q[i].k);}for (int i = 1; i <= que; ++i)write(res[i] == inf ? -1 : res[i]), putchar('\n');return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/883476.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java笔记-15、Web后端基础 分层解耦

三层架构 满足单一职责原则。Controller控制层:接收前端发送的请求,对请求进行处理并响应数据。 Service业务逻辑层:处理具体的业务逻辑。 Dao数据访问层(持久层):负责数据访问操作,包括数据的增删改查。浏览器发过来请求,首先访问Controller层,Controller调用Service…

框架ThinkPHP

引子:本章主要介绍ThinkPHP(PHP开发框架)的简单使用和一些安全问题。免责声明:本文章仅用于交流学习,因文章内容而产生的任何违法&未授权行为,与文章作者无关!!! 附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,若有错误欢迎指正! 1.5 🐘框架&a…

我的“DeepSeek服务不忙了”,腾讯云671B满血模型无限量调用攻略!

DeepSeek R1虽然免费,但是基本到了无法使用的状态。一两轮对话后,就开始服务忙了。好在这是一个开源模型,大量的第三方平台开始上线了。上一篇我们就讲过硅基流动。最近听闻腾讯云也上线了 DeepSeek-V3、DeepSeek-R1 满血版模型。而且可以免费不限量使用。具体规则如下: 添…

ACM寒假集训第五次专题任务

ACM寒假集训第五次专题任务 一、自然数的拆分问题 题目:解题思路: 使用了深度优先搜索,通过he判断何时输出,c标记长度控制输出,qs标记起始位置从小到大拆分。 AC代码: #include<iostream> using namespace std; int n,a[10],ans; void dfs(int he,int c,int qs) {i…

DeepSeekR1+Cherry Studio使用白嫖API和开源软件使用满血版模型!

使用Ollama本地运行,使用Ollama+ChatWise可视化运行,使用Ollama+ChatWise在Macbook Air M1 上运行。今天再来说一个方案。这个方案不是完全离线,但是模型能力会比离线的强。可以完全免费尝试,有几百到几千万的Token可以用。可以缓解DeepSeek R1官方服务繁忙无法使用的问题。…

DeepSeekR1 苹果macbook M1本地可视化运行!

过年了,就带了一台 macbook air 8g,DeepSeekR1的消息还是铺天盖地的来,我就想着在这台电脑上也装一个吧。经过简单的配置,最终也运行起来了,速度还可以。我这是首款M系列笔记本,也是现在最低配的 M 系列笔记本。这也就意味着所有M系列的苹果电脑都可以轻松运行DeepSeekR1…

11.A星寻路算法

14.A星寻路算法 题目 迷宫寻路需求,在一个迷宫游戏中,有一些怪物攻击主角,现在希望小怪物,能自动绕过迷宫中的障碍物,寻找到主角的所在。 思路 A星寻路算法(A*search algorithm),是一种用于寻找有效路径的算法。 简单的场景举例(简化问题),看一看A星寻路算法的工作过程。…

人間になりたい。

さよならはエモーション 僕は行く ずっと涙こらえ こらえ 忘れてたエモーション 僕は行く ずっと深い霧の 霧の向こうへ『……组建过,那就好。』 属于我的 Crychic,就在那个寒假啊。 或许更早些,始于一次英语单元测同时爆炸了的三个人,经过一次精彩地赶在元旦零点钟声前分解…

【THM】Security Principles(安全原则)-学习

了解安全三元组以及常见的安全模型和原则。本文相关的TryHackMe实验房间链接:https://tryhackme.com/room/securityprinciples 本文相关内容:了解安全三元组以及常见的安全模型和原则。介绍 网络安全已成为一个流行词;每家公司都声称其网络产品或网络服务是安全的,但事实上…

小米 R3G 路由器刷机教程(Pandavan)

小米 R3G 路由器以其高性价比和稳定的性能备受用户青睐。然而,原厂固件的功能相对有限,难以满足高级用户的个性化需求。刷机不仅可以解锁路由器的潜能,还能通过第三方固件实现更丰富的功能,如 DNS 解析、KMS 服务器、USB 管理等。本文旨在为小米 R3G 路由器用户提供详细的刷…

windows知道服务器的内网IP地址如何查看服务器的计算机名称

windows知道服务器的内网IP地址如何查看服务器的计算机名称windows知道服务器的内网IP地址如何查看服务器的计算机名称 nbtstat百度百科 https://baike.baidu.com/item/nbtstat/7578115 windows在局域网内查看ip地址对应的计算机名或者根据计算机名查ip https://blog.csdn.net/…