线段树与二分操作 vases and flowers ——hdu 4614
操作1,的关键是找到第一只和最后一只空花瓶,完全可以利用二分法查找,找第一只花瓶可以在[X,N]内查找,第一个位置pos1,最后一只花瓶则在[POS1,N]中找,然后更新[POS1,POS2],全部置1即可
代码:
#include<iostream>
using namespace std;
const int N = 5e4 + 5;
struct node {
int lazy;
int sum; //sum代表空花瓶的数量
}tree[N<<2];
int ls(int i) { return i << 2; }
int rs(int i) { return i << 2 | 1; }
int t, n, m, x, y, k;
//以下四个函数都是线段树的基本操作
void pushdown(int id, int l, int r) {
if (tree[id].lazy == -1) { return; }
int mid = (l + r) >> 1;
tree[ls(id)].sum = (mid - l + 1) * tree[id].lazy;
tree[rs(id)].sum = (r - mid) * tree[id].lazy;
tree[ls(id)].lazy = tree[rs(id)].lazy = tree[id].lazy;
tree[id].lazy = -1;
}
void pushup(int id) {
tree[id].sum = tree[ls(id)].sum + tree[rs(id)].sum;
}
void build(int id, int l, int r) {
if (l == r) {
tree[id].lazy = -1;
tree[id].sum = 0;
}
int mid = (l + r) >> 1;
build(ls(id), l, mid);
build(rs(id), mid + 1, r);
tree[id].lazy = -1;
pushup(id);
}
int query(int id, int l, int r, int x, int y) {
if (x <= l && y >= r) return tree[id].sum;
int ans = 0;
pushdown(id, l, r);
int mid = (l + r) >> 1;
if (x <= mid) ans += query(ls(id), l, mid, x, y);
if (y > mid) ans += query(rs(id), mid + 1, r, x, y);
return ans;
}
void update(int id, int l, int r, int x, int y, int d) { //d=1代表花瓶是空的,d=0代表花瓶是满的
if (x <= l && y >= r) {
tree[id].sum = (r - l + 1) * d;
tree[id].lazy = d;
return;
}
pushdown(id, l, r);
int mid = (l + r) >> 1;
if (x <= mid) update(ls(id), l, mid, x, y, d);
if (y > mid) update(rs(id), mid + 1, r, x, y, d);
pushup(id);
}
int binarysearch(int x, int n, int f) {
int l = x, int r = n;
while (l < r) {
int mid = (l + r) >> 1;
int t = query(1, 1, n, x, mid); //查找左边部分,从左边判断第f个空花瓶是在左边还是右边
if (t >= f) r = mid;
else l = mid + 1;
}
return r;
}
int main() {
cin >> t;
while (t--) {
cin >> n >> m;
build(1, 1, n);
for (int i = 1; i <= m; i++) {
cin >> k >> x >> y;
if (k == 1) {
x++; //保证区间为[1,N]
//首先查询[X,N]中是否有空花瓶
int t = query(1, 1, n, x, n);
if (t == 0) {
cout << "Can not put any one" << endl;
}
else {
t = min(y, t); //计算需要插花数量,此时的y代表收到花的数量
int s = binarysearch(x, n, 1); //搜索第一个空花瓶
int t = binarysearch(s, n, t); //搜索最后一个空花瓶
cout << s - 1 << " " << t - 1 << endl;
update(1, 1, n, s, t, 0);
}
}
else {
x++; y++;
int t = query(1, 1, n, x, y);
update(1, 1, n, x, y, 1);
cout << y - x + 1 - t;
}
}
cout << endl;
}
return 0;
}
线段树与二分操作 vases and flowers ——hdu 4614的更多相关文章
- L - Vases and Flowers HDU - 4614 线段树+二分
题意 给出一排空花瓶 有两种操作 1是 从A花瓶开始放F朵花 如果当前瓶有花就跳过前往下一个 直到花用完或者 瓶子到了最后一个为止 输出 成功放花的第一个和最后一个 如果没有输出 can not. ...
- L - Vases and Flowers - hdu 4614(区间操作)
题意:有两种操作,第一种从A开始插花,如果有花就跳到下一个,然后输出最后一个花瓶的编号,如果花瓶不够把多余的花丢掉.操作2把区间清空 分析:很明显的线段树操作,就是插花的时候麻烦一下,需要先找出来他剩 ...
- luoguP6619 [省选联考 2020 A/B 卷]冰火战士(线段树,二分)
luoguP6619 [省选联考 2020 A/B 卷]冰火战士(线段树,二分) Luogu 题外话1: LN四个人切D1T2却只有三个人切D1T1 很神必 我是傻逼. 题外话2: 1e6的数据直接i ...
- 线段树区间更新操作及Lazy思想(详解)
此题题意很好懂: 给你N个数,Q个操作,操作有两种,‘Q a b ’是询问a~b这段数的和,‘C a b c’是把a~b这段数都加上c. 需要用到线段树的,update:成段增减,query:区间求 ...
- 【BZOJ4552】排序(线段树,二分答案)
[BZOJ4552]排序(线段树,二分答案) 题面 BZOJ 题解 好神的题啊 直接排序我们做不到 怎么维护? 考虑一下,如果我们随便假设一个答案 怎么检验它是否成立? 把这个数设成\(1\),其他的 ...
- hdu 3436 线段树 一顿操作
Queue-jumpers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- CodeForces 914DBash and a Tough Math Puzzle(线段树的骚操作)
D. Bash and a Tough Math Puzzle time limit per test 2.5 seconds memory limit per test 256 megabytes ...
- BZOJ3110 [Zjoi2013]K大数查询 树套树 线段树 整体二分 树状数组
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3110 题意概括 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位 ...
- LOJ 2585 「APIO2018」新家 ——线段树分治+二分答案
题目:https://loj.ac/problem/2585 算答案的时候要二分! 这样的话,就是对于询问位置 x ,二分出一个最小的 mid 使得 [ x-mid , x+mid ] 里包含所有种类 ...
- BZOJ.4552.[HEOI2016/TJOI2016]排序(线段树合并/二分 线段树)
题目链接 对于序列上每一段连续区间的数我们都可以动态开点建一棵值域线段树.初始时就是\(n\)棵. 对于每次操作,我们可以将\([l,r]\)的数分别从之前它所属的若干段区间中分离出来,合并. 对于升 ...
随机推荐
- mysql面试汇总
最近一直在关注mysql方面的面试题目,并且从最近的面试情况来看,mysql在java后端的面试中,肯定是必问的题目,所以这里有必要对这块的内容进行总结,大家可以根据下面的导图进行重点复习, 引擎 1 ...
- 【GeoScene】一、创建、发布路网服务,并在代码中测试最短路径分析
前言 网上关于GeoScene及GeoScene API for JavaScript的资料太少了,官方的技术支持又太慢了,最近把在项目中踩过的坑分享出来: **版本信息** GeoScene Pro ...
- 【Java】使用Druid连接池的监控面板排查慢SQL
默认在后台服务的地址: http://localhost:8078/druid/login.html 账号信息放在配置文件中获取: server: port: 8078 spring: datasou ...
- 【爬虫】Java爬取省市县行政区域统计数据
前言 网上看了好几个Python爬虫来爬取省市县行政区域统计 官网除了省市县以外,还有区,街道,居委村委层级 https://zhuanlan.zhihu.com/p/512852193 所以自己用J ...
- 【郝斌C ST】指针 swap问题
C语言 指针 swap问题 在主函数种实现变量的交换 现在我们把这交换的行为封装进方法中 swap函数确实进行了交换,打印也是10和5了,但是下面a和b的结果还是5和10 - 形参i 和 形参j 并不 ...
- 【Mybatis-Plus】01 快速上手
[官网快速上手地址] https://mp.baomidou.com/guide/quick-start.html#%E5%88%9D%E5%A7%8B%E5%8C%96%E5%B7%A5%E7%A8 ...
- MD5签名生成,字典排序,实际生产
1.背景 作用:防止请求参数篡改,限制请求时效性: 常用方式:md5签名 关键:签名Key 常用签名原串排列:字母顺序.key1=value1&key2=value2....key (注意:签 ...
- css 样式 element.style 覆盖问题
问题: 我们在写网页定制样式的时候发现展示效果跟我们预想的不一样? 打开F12一看原来是element.style 覆盖的我定义的效果. 解决: 只要在定义的内容后面加上 !important 就行啦 ...
- 【A GUIDE TO CRC ERROR DETECTION ALGORITHM】 (译文2)
6. A Fully Worked Example 一个完全可行的例子 Having defined CRC arithmetic, we can now frame a CRC calculatio ...
- bat2exe
https://blog.csdn.net/qq_23452385/article/details/109145151