树状数组: #include<bits/stdc++.h> using namespace std; ; int id[maxn],tree[maxn],vis[maxn],num[maxn]; int n,m; struct Tree{ int l,r; int pos; }; Tree a[maxn]; ]; inline void read(int &x){ ; ') ch=getchar(); )+(x<<)+(ch^),ch=getchar(); } inline…
题目大意:给你一串数字,多次询问区间内数字的种类数 题解:莫队 卡点:洛谷数据加强,开了个$O(2)$ C++ Code: #include <cstdio> #include <algorithm> #define bsz 710 #define maxn 500010 #define N 1000010 int ans[maxn]; int n, m; int s[maxn], cnt[N]; struct Query { int l, r, pos; inline bool…
洛谷题目传送门 一血祭 向dllxl致敬! 算是YNOI中比较清新的吧,毕竟代码只有1.25k. 首先我们对着题意模拟,寻找一些思路. 每次选了一个最大的数后,它和它周围两个数都要减一.这样无论如何,我们都选不到旁边那两个数,只有第一次选的那个数会对答案产生它的大小的贡献. 于是就可以写出一个\(O(nm\log n)\)的暴力用来对拍了 #include<bits/stdc++.h> #define LL long long #define R register int #define G…