L - Vases and Flowers - hdu 4614(区间操作)
#include<algorithm>
#include<stdio.h>
using namespace std; #define lson r<<1
#define rson r<<1|1 const int MAXN = 1e5+; struct stgmentTree
{//sum花瓶的剩余量
int x, y, sum, cover;//cover, 操作1赋值为释放花瓶,操作2沾满花瓶
int mid(){return (x+y)>>;}
int len(){return y-x+;}
}a[MAXN<<];
int ans;
void Build(int r, int x, int y)
{
a[r].x = x, a[r].y = y;
a[r].sum = a[r].len(), a[r].cover = ; if(x == y)
return ; Build(lson, x, a[r].mid());
Build(rson, a[r].mid()+, y);
}
void Down(int r)
{
if(a[r].x != a[r].y && a[r].cover)
{
a[lson].cover = a[rson].cover = a[r].cover;
a[lson].sum = a[r].cover== ? : a[lson].len();
a[rson].sum = a[r].cover== ? : a[rson].len(); a[r].cover = ;
}
}
void Insert(int r, int x, int y, int op)
{
if(a[r].x == x && a[r].y == y)
{
ans += a[r].len()-a[r].sum;
a[r].cover = op;
a[r].sum = (op== ? : a[r].len()); return ;
} Down(r); if(y <= a[r].mid())
Insert(lson, x, y, op);
else if(x > a[r].mid())
Insert(rson, x, y, op);
else
{
Insert(lson, x, a[r].mid(), op);
Insert(rson, a[r].mid()+, y, op);
} a[r].sum = a[rson].sum + a[lson].sum;
}
int QueryPreSum(int r, int k)//求k前面的空花瓶数
{
Down(r); if(a[r].x == a[r].y)
return ;
if(k <= a[r].mid())
return QueryPreSum(lson, k);
else
return a[lson].sum + QueryPreSum(rson, k);
}
int QueryLast(int r, int p)//查找第p个花瓶位置
{
Down(r); if(a[r].x == a[r].y)
return a[r].x; if(a[lson].sum >= p)
return QueryLast(lson, p);
else
return QueryLast(rson, p-a[lson].sum);
} int main()
{
int T; scanf("%d", &T); while(T--)
{
int N, M, op, x, y, L, R; scanf("%d%d", &N, &M); Build(, , N-); while(M--)
{
scanf("%d%d%d", &op, &x, &y);
if(op == )
{
int PreSum = QueryPreSum(, x); if(PreSum == a[].sum)
printf("Can not put any one.\n");
else
{
L = QueryLast(, PreSum+); if(PreSum+y >= a[].sum)
PreSum = a[].sum;
else
PreSum += y;
R = QueryLast(, PreSum); Insert(, L, R, ); printf("%d %d\n", L, R);
}
}
else
{
ans = ;
Insert(, x, y, );
printf("%d\n", ans);
}
} printf("\n");
} return ;
}
/*
2
10 8
1 2 5
2 3 4
1 0 8
2 2 5
1 6 1
1 4 4
1 2 3
*/
L - Vases and Flowers - hdu 4614(区间操作)的更多相关文章
- L - Vases and Flowers HDU - 4614 线段树+二分
题意 给出一排空花瓶 有两种操作 1是 从A花瓶开始放F朵花 如果当前瓶有花就跳过前往下一个 直到花用完或者 瓶子到了最后一个为止 输出 成功放花的第一个和最后一个 如果没有输出 can not. ...
- HDU-4614 Vases and Flowers 线段树区间更新
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4614 线段树保存区间是否被覆盖以及区间的和即可,在询问的时候在线段树上二分查找就可以了...代码写得比 ...
- 【HDU 4614】Vases and Flowers(线段树区间更新懒惰标记)
题目0到n-1的花瓶,操作1在下标a开始插b朵花,输出始末下标.操作2清空[a,b]的花瓶,求清除的花的数量.线段树懒惰标记来更新区间.操作1,先查询0到a-1有num个空瓶子,然后用线段树的性质,或 ...
- 2013 多校联合2 D Vases and Flowers (hdu 4614)
Vases and Flowers Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others ...
- HDU 4614 Vases and Flowers(线段树+二分)
Vases and Flowers Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others ...
- HDU 4614 Vases and Flowers (2013多校2 1004 线段树)
Vases and Flowers Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others ...
- HDU-4614 Vases and Flowers(线段树区间更新+二分查找)
http://acm.hdu.edu.cn/showproblem.php?pid=4614 Time Limit: 4000/2000 MS (Java/Others) Memory Limi ...
- HDU 4578——Transformation——————【线段树区间操作、确定操作顺序】
Transformation Time Limit: 15000/8000 MS (Java/Others) Memory Limit: 65535/65536 K (Java/Others)T ...
- HDU 1754 I Hate It (Splay 区间操作)
题目大意 维护一个序列,支持两种操作 操作一:将第x个元素的值修改为y 操作二:询问区间[x,y]内的元素的最大值 解题分析 splay的区间操作,事先加入两个编号最小和最大的点防止操作越界. 具体的 ...
随机推荐
- ZOJ 3822 Domination(概率dp)
一个n行m列的棋盘,每天可以放一个棋子,问要使得棋盘的每行每列都至少有一个棋子 需要的放棋子天数的期望. dp[i][j][k]表示用了k天棋子共能占领棋盘的i行j列的概率. 他的放置策略是,每放一次 ...
- C#学习第四天
今天主要学习了结构方面的知识,首先是定义,代码: struct<typeName> { <memberDeclarations> } struct route { public ...
- SQL Server强制删除发布
今日发现SQL Server 中 存在以前(系统还原前)的发布内容,使用鼠标->右键,选择删除,失败. 可使用语句: EXEC SP_REMOVEDBREPLICATION '发布数据库名称 ...
- android-'Using 1.7 requires compiling with Android 4.4 (KitKat); currently using API 8'
解决的方案是将jdk1.7制定的版本定制为jdk.6.即 在eclipse中,右键项目->Properties->Java Compiler->enable "projec ...
- JS屏蔽右键菜单,复制,粘帖xxxxx........
//屏蔽右键菜单 document.oncontextmenu = function (event) { if (window.event) { event = window.event; } try ...
- 你好,C++(36)人参再好,也不能当饭吃!6.3 类是如何面向对象的
6.3 类是如何面向对象的 类作为C++与面向对象思想结合的产物,作为面向对象思想在C++中的载体,它的身上流淌着面向对象的血液.从类成员的构成到类之间的继承关系再到虚函数,到处都体现着面向对象封装 ...
- 基于GBT28181:SIP协议组件开发-----------第二篇SIP组件开发原理
原创文章,引用请保证原文完整性,尊重作者劳动,原文地址http://www.cnblogs.com/qq1269122125/p/3937590.html,qq:1269122125. 上一节中讲的S ...
- 测试最新的log4cplus1.1.2版
#include "stdafx.h" #include <sstream> class AB{ public: void do_test() { ...
- Java简介(4)-关键字
abstract assert boolean break byte byte case catch char class const continue default do-while double ...
- 打包静默安装参数(nsis,msi,InstallShield,InnoSetup)[转]
有时我们在安装程序的时候,希望是静默安装的,不显示下一步下一步,这编访问来教大家如何来操作,现在常用的制作安装程序的软件有, Microsoft Windows Installer , Windo ...