SUDTOJ 3323园艺问题 (线段树)
园艺问题
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
本巨养了一盆双色茉莉。这种花有一种特点:第i朵花在第Di天盛开,刚开时是紫色的,Ai天之后会变成白色,再过Bi天就会凋谢。如Di = 3,Ai = 4,Bi = 5,那么在第3至6天为紫色,第7至11天为白色,第11天之后就凋谢了。
现在给出一些事件,你需要按要求给出答案。
事件1:在第Di天开了一朵花,这朵花Ai天后变成白色,再过Bi天就会凋谢。
事件2:询问在第X天时,紫色花朵和白色花朵各有多少。
输入
输入包含多组。对于每组数据:
第一行包含一个整数n (1 <= n <= 300,000)。
接下来的n行,为下述两种格式的一种,分别代表事件1和事件2。
1 Di Ai Bi
2 X
对于所有数据有:1 <= Di,Ai,Bi <= 1,000,000,000 ,1 <= Ai <= 3,000,000,000;
输出
对于每个事件2输出一行,包含两个整数代表答案。
示例输入
4
1 3 2 3
2 4
1 2 1 1
2 10
示例输出
1 0
0 0
周赛的时候没有想到可以先全部输入进行离散化,再进行建树,我啸的一句话惊醒了我
#include <bits/stdc++.h>
#define LL long long
#define esp 1e-8
#define INF 0x3f3f3f3f
#define Fread() freopen("../in.in","r",stdin)
#define Fwrite() freopen("../out.out","w",stdout)
using namespace std;
const int Max = 301000;
typedef struct Flow
{
LL l,r,L,R;
}Flow;
union Flower
{
Flow F;
LL Q;
};
typedef struct Seg
{
int sum1;
int sum2;
} Tree;
int Sta[Max];
Flower FF[Max];
Tree T[Max*5];
LL Da[Max*2];
int top2,top3;
LL a,b,d;
int c;
int num1,num2;
void Update_down(int site,int L,int R)//向下更新
{
if(L==R)
{
return ;
}
T[site<<1].sum1+=T[site].sum1;
T[site<<1].sum2+=T[site].sum2;
T[site<<1|1].sum1+=T[site].sum1;
T[site<<1|1].sum2+=T[site].sum2;
T[site].sum1=T[site].sum2=0;
}
void Build(int L,int R,int site)//建树
{
T[site].sum1=0;
T[site].sum2=0;
if(L==R)
{
return ;
}
int mid=(L+R)>>1;
Build(L,mid,site<<1);
Build(mid+1,R,site<<1|1);
}
void Update(int L,int R,int l,int r,int site,int ans)//更新
{
if(L==l&&R==r)
{
if(ans==1)
{
T[site].sum1++;
}
else
{
T[site].sum2++;
}
return ;
}
int mid=(L+R)>>1;
if(r<=mid)
{
Update(L,mid,l,r,site<<1,ans);
}
else if(l>mid)
{
Update(mid+1,R,l,r,site<<1|1,ans);
}
else
{
Update(L,mid,l,mid,site<<1,ans);
Update(mid+1,R,mid+1,r,site<<1|1,ans);
}
}
void Query(int L,int R,int x,int site)//查询
{
if(L==R)
{
num1=T[site].sum1;
num2=T[site].sum2;
return ;
}
Update_down(site,L,R);
int mid=(L+R)>>1;
if(x<=mid)
{
Query(L,mid,x,site<<1);
}
else
{
Query(mid+1,R,x,site<<1|1);
}
}
int main()
{
int n;
while(~scanf("%d",&n))
{
vector<LL>Arr;
for(int i=1; i<=n; i++)
{
scanf("%d",&Sta[i]);
if(Sta[i]==1)
{
scanf("%lld %lld %lld",&d,&a,&b);
FF[i].F.l=d;
FF[i].F.r=d+a-1;
FF[i].F.L=d+a;
FF[i].F.R=d+a+b-1;
Arr.push_back(d);
Arr.push_back(d+a-1);
Arr.push_back(d+a);
Arr.push_back(d+a+b-1);
}
else
{
scanf("%lld",&FF[i].Q);
Arr.push_back(FF[i].Q);
}
}
sort(Arr.begin(),Arr.end());
Arr.erase(unique(Arr.begin(),Arr.end()),Arr.end());//去重
int ans=0;
map<LL,int>Ma;
for(int i=0; i<Arr.size(); i++)
{
Ma[Arr[i]]=++ans;//编号
}
Build(1,ans,1);
for(int i=1;i<=n;i++)
{
if(Sta[i]==1)
{
Update(1,ans,Ma[FF[i].F.l],Ma[FF[i].F.r],1,1);
Update(1,ans,Ma[FF[i].F.L],Ma[FF[i].F.R],1,2);
}
else
{
num1=num2=0;
Query(1,ans,Ma[FF[i].Q],1);
printf("%d %d\n",num1,num2);
}
}
}
return 0;
}
SUDTOJ 3323园艺问题 (线段树)的更多相关文章
- bzoj3932--可持久化线段树
题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1576 最长上升子序列的线段树优化
题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
- PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树
#44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...
- CF719E(线段树+矩阵快速幂)
题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...
- 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序
3779: 重组病毒 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 224 Solved: 95[Submit][Status][Discuss] ...
- 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集
3673: 可持久化并查集 by zky Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 1878 Solved: 846[Submit][Status ...
随机推荐
- css3效果
1. 放大图片: /*galleryImage css*/ a.galleryImage{ display:block;} .galleryImage img{ transition:all .4s ...
- SQL Server 2008 下载及安装教程
sql server 2008 是微软公司开发的一套数据库管理系统.是目前大型数据库中常用数据库之一.性能稳定,功能强大,是面向中大型企业的一款数据库解决方案.我们安装SqlServer2008的时候 ...
- mysqld诡异crash
突然收到告警短信,提示有一组服务器MHA已经切换,登录服务器后查看错误日志如下(其中相关insert语句已经处理): mysql版本:5.5.24 :: InnoDB: Assertion failu ...
- $.getJSON JSONP的新坑
神坑1:返回的内容必须是正规的json数据.如 { "firstName": "Bill", "lastName": "Gates ...
- tomcat重启session不过期的处理
tomcat关闭后重启,SESSION 仍然有效的处理方法很多时候明明在服务器上关闭了TOMCAT,但是客户端的表示 SESSION仍然在线,原因及解决方案如下: 每当正常关闭或者重启tomcat服务 ...
- 使用LVM对硬盘在线扩容
初始状态: root@control:/dev/nova-volumes# vgdisplay --- Volume group --- VG Name nova-volumes System ID ...
- js中把数据库时间转为正常值
function timeFormatter(value) { var da = new Date(parseInt(value.replace("/Date(", "& ...
- java基础学习总结——基础语法1
一.标识符
- MYSQL中创建存储过程实现向表中循环插入数据
首先在test数据库中先创建一个表test: CREATE TABLE test( ID INT PRIMARY KEY AUTO_INCREMENT ,test_name VARCHAR(20),t ...
- 【C51】74HC573芯片
74HC573是一个8位3态带锁存高速的逻辑芯片.下面介绍使用. 参数(仅供参考) Vcc 2~6V I in +-20mA I out +- 35mA 引脚图和引脚作用 ...