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 ...
随机推荐
- acm常见算法及例题
转自:http://blog.csdn.net/hengjie2009/article/details/7540135 acm常见算法及例题 初期:一.基本算法: (1)枚举. (poj17 ...
- HTTPS协议简介
一.HTTPS简介 百度已经于近日上线了全站 HTTPS 的安全搜索,默认会将 HTTP 请求跳转成 HTTPS.本文重点介绍 HTTPS 协议, 并简单介绍部署全站 HTTPS 的意义. HTTPS ...
- 您的服务器没有安装这个PHP扩展:OpenSSL(其他平台API同步需要)
今天在安装一个博客系统的时候提示这个错,在网上找了半天,自己慢慢弄出来的,具体如下: 1.找到你的php.ini 文件,将“;extension=php_openssl.dll”前面分号去掉. 2.复 ...
- bzoj4517: [Sdoi2016]排列计数--数学+拓展欧几里得
这道题是数学题,由题目可知,m个稳定数的取法是Cnm 然后剩下n-m本书,由于编号为i的书不能放在i位置,因此其方法数应由错排公式决定,即D(n-m) 错排公式:D[i]=(i-1)*(D[i-1]+ ...
- 2016HUAS暑假集训题1 A-士兵队列训练问题
A - 士兵队列训练问题 Description 某部队进行新兵队列训练,将新兵从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列,剩下的向小序号方向靠拢,再从 ...
- CentOS碰到两个问题,顺便解决了下
1.弹出界面 eth0: RTNETLINK answers: File exists 执行service network restart时报的错误 因为service network start造成 ...
- github标记
<template> <a href="https://github.com/lmk123/Runner" class="github-corner&q ...
- param STRING $username 要检查的用户名
检查用户名是否符合规定 两位以上的字母,数字,或者下划线,代码如下: php;auto-links:false;">/** * 检查用户名是否符合规定 * * @param STRIN ...
- shell bash ksh
shell 是一个交互性命令解释器.shell独立于操作系统,这种设计让用户可以灵活选择适合自己的shell.shell让你在命令行键入命令,经过shell解释后传送给操作系统(内核)执行. ...
- ubuntu 安装 nodejs
http://blog.csdn.net/caib1109/article/details/51804687 我的系统环境: Ubuntu 16.04 64位 本文内容亲测可用, 请放心食用 使用淘宝 ...