采花 flower
采花 flower
题目描述
萧芸斓是 Z 国的公主,平时的一大爱好是采花。
今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花。花园足够大,容纳 了 n 朵花,花有 c 种颜色(用整数 1-c 表示),且花是排成一排的,以便于公主采花。
公主每次采花后会统计采到的花的颜色数,颜色数越多她会越高兴!同时,她有一癖好, 她不允许最后自己采到的花中,某一颜色的花只有一朵。为此,公主每采一朵花,要么此前 已采到此颜色的花,要么有相当正确的直觉告诉她,她必能再次采到此颜色的花。
由于时间关系,公主只能走过花园连续的一段进行采花,便让女仆福涵洁安排行程。福 涵洁综合各种因素拟定了 m 个行程,然后一一向你询问公主能采到多少朵花(她知道你是编 程高手,定能快速给出答案!),最后会选择令公主最高兴的行程(为了拿到更多奖金!)。
输入
第一行四个空格隔开的整数 n、c 以及 m。
接下来一行 n 个空格隔开的整数,每个数在[1, c]间,第 i 个数表示第 i 朵花的颜色。
接下来 m 行每行两个空格隔开的整数 l 和 r(l ≤ r),表示女仆安排的行程为公主经 过第 l 到第 r 朵花进行采花。
输出
共m行,每行一个整数,第i个数表示公主在女仆的第i个行程中能采到的花的颜色数。
样例输入
5 3 5
1 2 2 3 1
1 5
1 2
2 2
2 3
3 5
样例输出
2
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 的花各一朵,公主不采。
【数据范围】
对于 20%的数据,n ≤ 102,c ≤ 102,m ≤ 102;
对于 50%的数据,n ≤ 105,c ≤ 102,m ≤ 105;
对于 100%的数据,1 ≤ n ≤106,c ≤ n,m ≤ 106。
来源
解法好牛
首先离线处理询问
按l从小到大排序
维护区间(l,n)
把[l, n]内每种颜色的第一朵花标记成1,其余标记为0,那么[l, r]内标记的和就是区间内花的种类数;
每种颜色的第一朵花标记成1、第二朵花标记成-1,其余标记为0,那么[l, r]内标记的和就是区间内相同颜色只有一朵的花的种类数;
上面两数之差就是答案
树状数组维护即可
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#define maxn 1000006
using namespace std;
int n,c,m,s[maxn],a[maxn],b[maxn],num[maxn],t,top[maxn],ans[maxn];
vector<int>g[maxn];
struct no{
int id,l,r;
}q[maxn];
bool cmp(no a, no b){
return a.l<b.l;
}
void pa(int k,int v){
for(int i=k;i<=n;i+=i&-i)a[i]+=v;
}
void pb(int k,int v){
for(int i=k;i<=n;i+=i&-i)b[i]+=v;
}
int aska(int k){
int sum=0;
for(int i=k;i;i-=i&-i)sum+=a[i];
return sum;
}
int askb(int k){
int sum=0;
for(int i=k;i;i-=i&-i)sum+=b[i];
return sum;
}
int main(){
cin>>n>>c>>m;
for(int i=1;i<=n;i++){
scanf("%d",&s[i]);
g[s[i]].push_back(i);
num[s[i]]++;
if(num[s[i]]==1){
pa(i,1),pb(i,1);
}
if(num[s[i]]==2)pb(i,-1);
}
for(int i=1;i<=m;i++){
scanf("%d%d",&q[i].l,&q[i].r);
q[i].id=i;
}
sort(q+1,q+m+1,cmp);
int la=1;
for(int i=1;i<=m;i++){
while(la<q[i].l){
if(top[s[la]]+1<g[s[la]].size()){
int nex=g[s[la]][top[s[la]]+1];
pa(la,-1);pa(nex,1);
pb(la,-1);pb(nex,2);
top[s[la]]++;
if(top[s[la]]+1<g[s[la]].size()){
//cout<<la<<' '<<g[s[la]][top[s[la]]]<<' '<<g[s[la]][top[s[la]]+1]<<endl;
nex=g[s[la]][top[s[la]]+1];
pb(nex,-1);
}
}
la++;
}
int t1=aska(q[i].r),t2=askb(q[i].r);
//cout<<"aaa "<<q[i].l<<' '<<q[i].r<<' '<<t1<<' '<<t2<<endl;
ans[q[i].id]=t1-t2;
}
for(int i=1;i<=m;i++)printf("%d\n",ans[i]);
return 0;
}
采花 flower的更多相关文章
- BZOJ 2743 【HEOI2012】 采花
题目链接:采花 这道题一眼看去,一个很显然的想法就是莫队.但是数据范围是\(10^6\)级别的,莫队显然已经过不去了. 其实感觉这道题和以前写过的一道题HH的项链很像.只不过那道题要求的是区间出现次数 ...
- 【HEOI2012】采花 BZOJ2743
Description 萧芸斓是Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一 ...
- 采花 bzoj 2743
采花(1s 128MB)flower [题目描述] 萧芸斓是Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整 ...
- BZOJ 2743: [HEOI2012]采花
2743: [HEOI2012]采花 Time Limit: 15 Sec Memory Limit: 128 MBSubmit: 2056 Solved: 1059[Submit][Status ...
- [bzoj2743][HEOI2012]采花(树状数组+离线)
2743: [HEOI2012]采花 Time Limit: 15 Sec Memory Limit: 128 MBSubmit: 1832 Solved: 954[Submit][Status] ...
- cdoj 1489 老司机采花
地址:http://acm.uestc.edu.cn/#/problem/show/1489 题目: 老司机采花 Time Limit: 3000/1000MS (Java/Others) M ...
- 数据结构(树状数组):HEOI2012 采花
[题目描述] 萧薰儿是古国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一排的,以便 ...
- BZOJ 2743: [HEOI2012]采花( 离线 + BIT )
处理出每个数下一个出现的位置, 然后按左端点排序回答询问.处理当前数去除的影响 ------------------------------------------------------------ ...
- [BZOJ2743] [HEOI2012] 采花 (树状数组)
Description 萧芸斓是Z国的公主,平时的一大爱好是采花. 今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了n朵花,花有c种颜色(用整数1-c表示),且花是排成一 ...
随机推荐
- pyqt4 python2.7 中文乱码的解决方法
import sysimport localefrom PyQt4.QtGui import *from PyQt4.QtCore import *from untitled import Ui_Di ...
- 毛毛虫组【Beta】Scrum Meeting 2
第二天 日期:2019/6/24 前言 第二次会议: 时间:6月24日 地点:教10-503 内容:此次会议主要是进一步完善系统,分配进行文档的准备工作. 1.1 今日完成任务情况以及遇到的问题. 今 ...
- C#事件与接口编程实例
很多初学c#的朋友对于事件与接口感到迷惑不解,不明白它们之间的关系,下面我就用实例来简单的分析讲解一下. 事件,用event修饰符来代表一个事件,我们要创建一个C#事件必须按以下顺序来扫行: 1,创建 ...
- 【dp】奶牛家谱 Cow Pedigrees
令人窒息的奶牛题 题目描述 农民约翰准备购买一群新奶牛. 在这个新的奶牛群中, 每一个母亲奶牛都生两个小奶牛.这些奶牛间的关系可以用二叉树来表示.这些二叉树总共有N个节点(3 <= N < ...
- python笔记-tuple元组的方法
#!/usr/bin/env python #-*- coding:utf-8 -*- # 创建空元组 tuple1 = () print(tuple) # 创建带有元素的元组 # 元组中的类型可以不 ...
- Redux百行代码千行文档
接触Redux不过短短半年,从开始看官方文档的一头雾水,到渐渐已经理解了Redux到底是在做什么,但是绝大数场景下Redux都是配合React一同使用的,因而会引入了React-Redux库,但是正是 ...
- 删除Zend Studio项目
导入了过大的项目,导致很卡,且Close Project和Delete操作不了,一直无响应. 调整项目目录下的隐藏文件夹,删除对应项目: E:\www\.metadata\.plugins\org.e ...
- Tesseract-ocr视觉学习-验证码识别及python import pytesseract使用
Tesseract-OCR的简单使用与训练 最近看到某个网站提交数据要提交验证码,用tesseract自带的识别, 识别出来是什么鬼,0-9识别成了什么玩意! so决定自己训练下tesseract.. ...
- BootCDN 开源项目免费 CDN 加速服务,Jquery插件库
2017-11-17 19:38:32 免费好用的在线 css js 文件引用 BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务 Jquery插件库 .
- 服务器常说的U是什么意思?
U是英文单词:unit 所说的1U和2U,是服务器的厚度,1U大概是相当于机柜的两个小格子,2U是四个格子.1U大概是4.45厘米(1U=1.75英寸,1英寸=2.54CM).以下这个是图片: