这是一个线段树的题目;

我记得一个月前在cf上也做过一个类似的题目;

 #include<cstdio>
#include<cstring>
#include<algorithm>
#define maxn 100010
#define bon 1000010
using namespace std;
int cover[bon<<];
int f[maxn<<],ans[maxn<<];
struct line
{
int x1,y1,x2,y2;
bool operator<(const line &t)const
{
return y1<t.y1;
}
} li[maxn<<]; void pushdown(int rt)
{
if(cover[rt]>=)
{
cover[rt<<]=cover[rt<<|]=cover[rt];
cover[rt]=-;
}
} int query(int x,int l,int r,int rt)
{
if(cover[rt]>=) return cover[rt];
int mid=(l+r)>>;
pushdown(rt);
if(x<=mid)return query(x,l,mid,rt<<);
else return query(x,mid+,r,rt<<|);
} void update(int L,int R,int i,int l,int r,int rt)
{
if(L<=l&&R>=r)
{
cover[rt]=i;
return;
}
int mid=(l+r)>>;
pushdown(rt);
if(L<=mid)update(L,R,i,l,mid,rt<<);
if(R>mid)update(L,R,i,mid+,r,rt<<|);
}
int n,q,xx;
void solve(int x)
{
int k=query(x,,bon,);
if(li[k].y1!=li[k].y2)x=ans[k];
if(f[k]==n)printf("%d\n",x);
else printf("%d %d\n",x,li[f[k]].y1);
} int main()
{
while(scanf("%d%d",&n,&q)!=EOF)
{
memset(cover,-,sizeof cover);
for(int i=; i<n; i++)
{
scanf("%d%d%d%d",&li[i].x1,&li[i].y1,&li[i].x2,&li[i].y2);
if(li[i].y1<li[i].y2)
{
swap(li[i].x1,li[i].x2);
swap(li[i].y1,li[i].y2);
}
}
li[n].x1=,li[n].x2=bon,li[n].y1=bon+,li[n].y2=bon+;
sort(li,li+n+);
for(int i=n; i>=; i--)
{
if(li[i].y1==li[i].y2) f[i]=i;
else
{
int k=query(li[i].x1,,bon,);
f[i]=f[k];
if(li[k].y1==li[k].y2) ans[i]=li[i].x1;
else ans[i]=ans[k];
}
int l=li[i].x1,r=li[i].x2;
if(l>r)swap(l,r);
update(l,r,i,,bon,);
}
while(q--)
{
scanf("%d",&xx);
solve(xx);
}
}
return ;
}

UVA 12647 Balloon的更多相关文章

  1. uva 1354 Mobile Computing ——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5

  2. UVA 10564 Paths through the Hourglass[DP 打印]

    UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...

  3. UVA 11404 Palindromic Subsequence[DP LCS 打印]

    UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...

  4. UVA&&POJ离散概率与数学期望入门练习[4]

    POJ3869 Headshot 题意:给出左轮手枪的子弹序列,打了一枪没子弹,要使下一枪也没子弹概率最大应该rotate还是shoot 条件概率,|00|/(|00|+|01|)和|0|/n谁大的问 ...

  5. UVA计数方法练习[3]

    UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...

  6. UVA数学入门训练Round1[6]

    UVA - 11388 GCD LCM 题意:输入g和l,找到a和b,gcd(a,b)=g,lacm(a,b)=l,a<b且a最小 g不能整除l时无解,否则一定g,l最小 #include &l ...

  7. UVA - 1625 Color Length[序列DP 代价计算技巧]

    UVA - 1625 Color Length   白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束   和模拟赛那道环形DP很想,计算这 ...

  8. UVA - 10375 Choose and divide[唯一分解定理]

    UVA - 10375 Choose and divide Choose and divide Time Limit: 1000MS   Memory Limit: 65536K Total Subm ...

  9. UVA - 11584 Partitioning by Palindromes[序列DP]

    UVA - 11584 Partitioning by Palindromes We say a sequence of char- acters is a palindrome if it is t ...

随机推荐

  1. [ImportNew]Java中的并发处理

    本文来源:http://www.importnew.com/14506.html 这篇文章讨论了Java应用中并行处理的多种方法.从自己管理Java线程,到各种更好几的解决方法,Executor服务. ...

  2. EXT.NET学习笔记(一) 下载配置使用

    新公司使用ext.net开发,开始学习该知识: 首先下载ext.net,目前我使用的版本为1.7,该版本免费,基本的功能也够用,使用ext.net进行开发时强烈建议使用VS2015,能便捷的提示,大大 ...

  3. ASP.NET伪静态-无法读取配置文件,因为它超过了最大文件大小的解决办法

    一直都在使用微软URLRewriter,具体的使用方法我就不多说了,网上文章很多. 但最近遇到一个问题,就是当web.config文件里面设置伪静态规则过多,大于2M的时候,就报错:无法读取配置文件, ...

  4. OPENSSL中RSA私钥文件(PEM格式)解析【一】

    http://blog.sina.com.cn/s/blog_4fcd1ea30100yh4s.html 在PKCS#1 RSA算法标准中定义RSA私钥语法为: RSAPrivateKey ::= S ...

  5. JS基本类型和引用类型的值

    JS中可以把变量分成两部分,基本类型和引用类型. 基本类型比较简单,包括:Undefined.Null.Boolean.Number和String,基本类型值就是简单的数据段:引用类型值可能由多个值构 ...

  6. [ADO.NET]写入数据

    关键字:.NET,SQL SERVER,SQLBULKCOPY 插入一条数据的操作(SqlCmd). public void InsertOneIntoSourceDB() { if (DBConne ...

  7. Mysql的权限管理

    权限管理 创建用户 语法:     create user '用户名'[@'主机名'][identified by '密码']; 示例: 说明:     用户名必须使用引号     '主机名'可以是以 ...

  8. a标签根据js返回值判断页面是否跳转

    a标签再跳转之前先判断是否符合条件,符合可以跳转,不符合不可以跳转. 自己遇到的问题是:在js方法中根据条件就return结果,但是不行. 原因是:在js方法中return后不会结束整个js方法(ac ...

  9. debian 学习记录-4 -关于linux -2

    来源:<Debian标准教程>王旭 著 Slackware.Debian.RedHat.SuSE 这4种发布版是当今大部分发布版的前去,虽然SuSE衍生自Slackware,但由于其技术变 ...

  10. rsync+inotity

    rsync默认端口:873xinetd默认服务 inotify参数详解inotifywait-r:递归-q:只打印事件-m:始终监听事件--excludei:排除--timefmt:时间格式--for ...