BZOJ 2743: [HEOI2012]采花
2743: [HEOI2012]采花
Time Limit: 15 Sec Memory Limit: 128 MB
Submit: 2056 Solved: 1059
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 2 3 1
1 5
1 2
2 2
2 3
3 5
Sample Output
0 0 1 0
【样例说明】
询问[1, 5]:公主采颜色为1和2的花,由于颜色3的花只有一朵,公主不采;询问[1, 2]:颜色1和颜色2的花均只有一朵,公主不采;
询问[2, 2]:颜色2的花只有一朵,公主不采;
询问[2, 3]:由于颜色2的花有两朵,公主采颜色2的花;
询问[3, 5]:颜色1、2、3的花各一朵,公主不采。
HINT
【数据范围】
对于100%的数据,1 ≤ n ≤ 10^6,c ≤ n,m ≤10^6。
Source
用莫队据说会TLE,有人实践了一下,@NEIGHTHORN
那就只好离线+树状数组喽,预处理每种颜色的下一个出现位置,从左向右枚举左端点即可。
#include <bits/stdc++.h> #define siz 1024 inline int get_c(void)
{
static char buf[siz];
static char *head = buf + siz;
static char *tail = buf + siz; if (head == tail)
fread(head = buf, , siz, stdin); return *head++;
} inline int get_i(void)
{
register int ret = ;
register int neg = false;
register int bit = get_c(); for (; bit < ; bit = get_c())
if (bit == '-')neg ^= true; for (; bit > ; bit = get_c())
ret = ret * + bit - ; return neg ? -ret : ret;
} #define N 1000005 int n;
int c;
int m;
int lt[N];
int rt[N];
int ans[N];
int ord[N];
int num[N];
int nxt[N];
int lst[N];
int fst[N];
int tree[N]; inline bool cmp(int a, int b)
{
return lt[a] < lt[b];
} inline int ask(int p)
{
int ret = ;
for (; p; p -= p&-p)
ret += tree[p];
return ret;
} inline void add(int p, int k)
{
for (; p <= n; p += p&-p)
tree[p] += k;
} signed main(void)
{
n = get_i();
c = get_i();
m = get_i(); for (int i = ; i <= n; ++i)
num[i] = get_i(); for (int i = ; i <= m; ++i)
{
ord[i] = i;
lt[i] = get_i();
rt[i] = get_i();
} std::sort(ord + , ord + + m, cmp); nxt[n + ] = n + ; for (int i = ; i <= c; ++i)
lst[i] = n + , fst[i] = ; for (int i = n; i >= ; --i)
nxt[i] = lst[num[i]], lst[num[i]] = i; for (int i = ; i <= n; ++i)
if (!fst[num[i]])
{
add(nxt[i], );
fst[num[i]] = ;
} int left = ; for (int i = ; i <= m; ++i)
{
while (left < lt[ord[i]])
{
add(nxt[left], -);
add(nxt[nxt[left]], );
++left;
} ans[ord[i]] = ask(rt[ord[i]]);
} for (int i = ; i <= m; ++i)
printf("%d\n", ans[i]);
}
#include <bits/stdc++.h> const int mxn = ; int n, m, col[mxn]; namespace BIT
{
int tree[mxn]; void add(int p, int v)
{
for (; p <= n; p += p&-p)
tree[p] += v;
} int qry(int p)
{
int ret = ; for (; p >= ; p -= p&-p)
ret += tree[p]; return ret;
}
} namespace PRW
{
int nxt[mxn];
int lst[mxn]; void prework(void)
{
nxt[n + ] = n + ; for (int i = ; i <= n + ; ++i)
lst[i] = n + ; for (int i = n; i >= ; --i)
{
nxt[i] = lst[col[i]];
lst[col[i]] = i;
} for (int i = ; i <= n; ++i)
BIT::add(nxt[lst[i]], );
}
} namespace QRY
{
struct query
{
int l, r, ans;
}qry[mxn]; int hd[mxn], to[mxn], nt[mxn], tot; void add(int u, int v)
{
nt[++tot] = hd[u], to[tot] = v, hd[u] = tot;
} void read(int i)
{
scanf("%d%d", &qry[i].l, &qry[i].r); add(qry[i].l, i);
}
} signed main(void)
{
scanf("%d%*d%d", &n, &m); for (int i = ; i <= n; ++i)
scanf("%d", col + i); PRW::prework(); for (int i = ; i <= m; ++i)
QRY::read(i); for (int i = ; i <= n; ++i)
{
for (int j = QRY::hd[i]; j; j = QRY::nt[j])
{
int q = QRY::to[j]; QRY::qry[q].ans = BIT::qry(QRY::qry[q].r);
} BIT::add(PRW::nxt[i], -);
BIT::add(PRW::nxt[PRW::nxt[i]], );
} for (int i = ; i <= m; ++i)
printf("%d\n", QRY::qry[i].ans);
}
@Author: YouSiki
BZOJ 2743: [HEOI2012]采花的更多相关文章
- BZOJ 2743: [HEOI2012]采花( 离线 + BIT )
处理出每个数下一个出现的位置, 然后按左端点排序回答询问.处理当前数去除的影响 ------------------------------------------------------------ ...
- BZOJ 2743: [HEOI2012]采花 离线树状数组
2743: [HEOI2012]采花 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2743 Description 萧芸斓是Z国的公主, ...
- 洛谷 P2056 BZOJ 2743 [HEOI2012]采花
//表示真的更喜欢洛谷的题面 题目描述 萧芸斓是 Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了 n 朵花,花有 c 种颜色(用整数 ...
- BZOJ 2743: [HEOI2012]采花 [树状数组 | 主席树]
题意: 查询区间中出现次数$>2$的颜色个数 一眼主席树,区间中$l \le last[i] \le r$的个数减去$l \le last[last[i]] \le r$的个数,搞两颗主席树来做 ...
- ●BZOJ 2743 [HEOI2012]采花
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=2743 题解: 树状数组,离线 求区间里面有多少种出现次数大于等于 2 的颜色. 类似某一个题 ...
- bzoj 2743: [HEOI2012]采花【树状数组】
离线,按照l排序 注意到在区间里出现两次的颜色才有贡献,所以记录一个ne[i]表示i后第一个和i同色的花,维护一个l,每次处理询问的时候l单调右移,树状数组维护,在ne[ne[i]]位置++,在ne[ ...
- 2743: [HEOI2012]采花
Description 萧芸斓是Z国的公主,平时的一大爱好是采花.今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花 .花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一 ...
- 【BZOJ】2743: [HEOI2012]采花(树状数组)
题目 传送门:QWQ 分析 已经凉凉.看错数据范围敲了发莫队........ 和HH的项链差不多,把每种颜色之前的颜色到再之前的颜色这段区间 区间加. 区间加就树状数组特技 代码 #include & ...
- [bzoj2743][HEOI2012]采花(树状数组+离线)
2743: [HEOI2012]采花 Time Limit: 15 Sec Memory Limit: 128 MBSubmit: 1832 Solved: 954[Submit][Status] ...
随机推荐
- SQL Server快捷键
SQL Server快捷键 金刚 SQL Server 快捷键 自己汇总的键盘操作快捷键 F7 切换到对象资源管理器 F5 执行T-Sql语句 F6 跳转到列属性 Alt+Enter 表属性 其实还有 ...
- Servlet、Filter、Listener、Interceptor
首先,JSP/Servlet规范中定义了Servlet.Filter.Listener这三种角色,并没有定义Interceptor这个角 色,Interceptor是某些MVC框架中的角色,比如Str ...
- js中A包含B的写法与分割字符串的方法
在java中A包含B的写法 if(A.contains(B)){ ... } 在js中没有contains方法,应该使用下面这种方法: var an = "传染性.潜伏性.破坏性" ...
- shell九九乘法表
#!/bin/bash ..}; do ..}; do if [ $x -ge $y ]; then echo -ne "$y*$x=$[$y*$x] \t" fi done ec ...
- J2EE基础之JSP
J2EE基础之JSP 1.JSP简介 JSP是JavaServer的缩写,是由Sun Microsystems公司倡导.许多公司参与一起建立的一种动态网页技术标准.在HTML文件中加入Java程序代码 ...
- 基于Fast Bilateral Filtering 算法的 High-Dynamic Range(HDR) 图像显示技术。
一.引言 本人初次接触HDR方面的知识,有描述不正确的地方烦请见谅. 为方便文章描述,引用部分百度中的文章对HDR图像进行简单的描述. 高动态范围图像(High-Dynamic Range,简称HDR ...
- http status 状态码汇总
常见HTTP状态码 200 OK 301 Moved Permanently 302 Found 304 Not Modified 307 Temporary Redirect 400 Bad Req ...
- Java程序设计之线程池应用
这里简单说一个线程池的小应用,从控制台输入线程访问的线程数量,输出输出工作的线程名,之前先构造一个包含了5条线程的对象. 代码: import java.util.Scanner; import ja ...
- [自学总结] Unity5.3 API 之 Audio Mixer
unity5.3 - API - class AudioMixer 和 class AudioMixerGrou问题:之前版本声音的渐入渐出太生硬,声音的特效需要自己手动编写.分析:5.0版本重大更新 ...
- concat() 方法用于连接两个或多个数组。
我们创建了三个数组,然后使用 concat() 把它们连接起来: <script type="text/javascript"> var arr = new Array ...