Dynamic len(set(a[L:R])) UVA - 12345(这么过分一定要写博客)
给出一个有n个元素的数组,有以下两种操作:Q x y,求出区间[x,y)内不同元素的个数,
M x y,把第x个元素的值修改为y。注意题目中的下标是从0开始的
这题超级超级坑
妈的一个水题找了几个小时的BUG
这样AC
这样WA
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn = 1e6 + ;
int n, m, L, R, ans, sz, qsz, tsz;
int a[maxn], ANS[maxn], num[maxn], now[maxn], flag[maxn];
struct node {
int l, r, id, t;
node() {}
node(int l, int r, int id, int t): l(l), r(r), id(id), t(t) {}
bool operator < (const node &b)const {
if (l / sz == b.l / sz) {
if (r / sz == b.r / sz) return t < b.t;
return r < b.r;
}
return l < b.l;
}
} qu[maxn];
struct node1 {
int pos, x, y;
node1() {}
node1(int pos, int x, int y): pos(pos), x(x), y(y) {}
} c[maxn];
void add(int val) {
if (num[a[val]] == ) ans++;
num[a[val]]++; }
void del(int val) {
num[a[val]]--;
if (num[a[val]] == ) ans--;
}
void change(int pos, int x) {
if (L <= pos && pos <= R) del(pos);
a[pos] = x;
if (L <= pos && pos <= R) add(pos);
}
int main() {
scanf("%d%d", &n, &m);
sz = (int)sqrt((double)n + 0.5);
qsz = tsz = ;
for (int i = ; i <= n ; i++) {
scanf("%d", &a[i]);
now[i] = a[i];
}
for (int i = ; i <= m ; i++) {
char s[];
scanf("%s", s);
if(s[] == 'Q') {
int l, r;
scanf("%d%d", &l, &r);
l++;
qsz++;
qu[qsz] = node(l, r, qsz, tsz);
} else {
int pos, x;
scanf("%d%d", &pos, &x);
pos++;
tsz++;
c[tsz].pos = pos, c[tsz].x = x, c[tsz].y = now[pos];
now[pos] = x;
}
}
for (int i = ; i <= n ; i++) now[i] = a[i];
int t = ;
sort(qu + , qu + + qsz);
L = , R = , ans = ;
for (int i = ; i <= qsz ; i++) {
while(L < qu[i].l) del(L++);
while(R > qu[i].r) del(R--);
while(L > qu[i].l) add(--L);
while(R < qu[i].r) add(++R);
while(t < qu[i].t) t++, change(c[t].pos, c[t].x);
while(t > qu[i].t) change(c[t].pos, c[t].y), t--;
ANS[qu[i].id] = ans;
}
for (int i = ; i <= qsz ; i++)
printf("%d\n", ANS[i]);
return ;
}
Dynamic len(set(a[L:R])) UVA - 12345(这么过分一定要写博客)的更多相关文章
- (待修莫队 没过! 抽空在检查)Dynamic len(set(a[L:R])) UVA - 12345
#include <iostream> #include <cstdio> #include <sstream> #include <cstring> ...
- Uva 3767 Dynamic len(set(a[L:R])) 树套树
Dynamic len(set(a[L:R])) Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 https://uva.onlinejudge.org/in ...
- 【题解】Luogu UVA12345 Dynamic len(set(a[L:R]))
原题传送门 这题要用动态莫队,我博客里有介绍 这道题和luogu P1903 [国家集训队]数颜色 / 维护队列差不多,解法就在上面那篇博客里qaq 主要的问题是如何排序? 排序有三个关键字: 1.左 ...
- 分块入门(根据hzwer的博客。。)(右端点是r不是n。。)
1.区间更新单点查询 #include <bits/stdc++.h> using namespace std; #define ll long long #define maxn 100 ...
- UVA 12345 Dynamic len(带修莫队)
Dynamic len [题目链接]Dynamic len [题目类型]带修莫队 &题解: 莫队可以单点更改,只要再多加一维,代表查询次数,排序的时候3个关键字. 之后循环离线的时候,先暴力时 ...
- UVA 12345 Dynamic len(set(a[LR]))
题意:询问区间唯一元素个数,单点修改. 分析: 借助Unique snowflakes, Can you answer these queries II的思想,唯一性可以借助元素上一次出现的位置来判断 ...
- 在一个由 'L' , 'R' 和 'X' 三个字符组成的字符串(例如"RXXLRXRXL")中进行移动操作。一次移动操作指用一个"LX"替换一个"XL",或者用一个"XR"替换一个"RX"。现给定起始字符串start和结束字符串end,请编写代码,当且仅当存在一系列移动操作使得start可以转换成end时, 返回True。
在一个由 'L' , 'R' 和 'X' 三个字符组成的字符串(例如"RXXLRXRXL")中进行移动操作.一次移动操作指用一个"LX"替换一个"XL ...
- CF 给你三个数字L, R, K,问在[L, R]范围内有多少个数字满足它每一位不同数字不超过k个,求出它们的和(数位DP)
题意: 给你三个数字L, R, K,问在[L, R]范围内有多少个数字满足它每一位不同数字不超过k个,求出它们的和 分析:考虑用状态压缩 , 10给位0~9 , 如果之前出现过了某个数字x ,那就拿当 ...
- 中间值为什么为l+(r-l)/2,而不是(l+r)/2
二分法的算法中,我们看到一些代码里取中间值: MID=l+(r-l)/2; 为什么是这个呢?不就是(l+r)/2吗?为什么要多此一举呢? 其实还是有不一样的,看看他们的区别吧: l,r是指针的时候只能 ...
随机推荐
- MyBatis中文文档
http://mybatis.github.io/mybatis-3/zh/index.html
- js经典试题之w3规范系列
js经典试题之w3规范系列 1:w3c 制定的 javascript 标准事件模型的正确的顺序? 答案:事件捕获->事件处理->事件冒泡 解析:先事件捕获从windows > doc ...
- Thunder团队第六周 - Scrum会议1
Scrum会议1 小组名称:Thunder 项目名称:i阅app Scrum Master:王航 工作照片: 参会成员: 王航(Master):http://www.cnblogs.com/wangh ...
- Java学习个人备忘录之抽象类
抽象类 特点:1. 方法只有声明没有实现时,该方法就是抽象方法,需要被abstract修饰,抽象方法必须定义在抽象类中.该类必须也被abstract修饰2. 抽象类不可以被实例化. 为什么? 因为调 ...
- 哈希表 STL map
计数排序时我们使用一个数组来记录出现的数字的次数,而当数据范围太大时,无法建立一个那么大地数组(而且可能空间利用率很低,太浪费),此时可以改用hash table . binary search tr ...
- 《学习OpenCV》课后习题解答6
题目:(P104) 使用cvCmp()创建一个掩码.加载一个真实的图像.使用cvsplit()将图像分割成红,绿,蓝三个单通道图像. a.找到并显示绿图. b.克隆这个绿图两次(分别命名为clone1 ...
- YaoLingJump开发者日志(四)
这么有意思的游戏没有剧情怎么行?开始剧情的搭建. 用到了LGame中的AVGScreen,确实是个好东西呢,只需要准备图片和对话脚本就行了. 经过不断的ps,yy,ps,yy,游戏开头的剧 ...
- HDU 2161 Primes
http://acm.hdu.edu.cn/showproblem.php?pid=2161 Problem Description Write a program to read in a list ...
- 生成以指定字符为开头的md5值(6位数字)
以下脚本的功能是生成以指定字符为开头的md5值 #-*- coding:utf-8 -*- #脚本功能:生成以指定字符为开头的md5值(6位数字) import hashlib import rand ...
- 【Redis】- 总结精讲
本文围绕以下几点进行阐述 1.为什么使用redis2.使用redis有什么缺点3.单线程的redis为什么这么快4.redis的数据类型,以及每种数据类型的使用场景5.redis的过期策略以及内存淘汰 ...