uoj

考虑把那最后一条直线拎出来,并且旋转到和\(y\)轴平行(其他直线同时一起旋转),然后它和其他直线相交形成\(n+1\)个区间,现在要知道这些区间是否处在一个面积有限的区域

可以发现一段在有限区域当且仅当区间的两侧区域都是有限的.所以对线的两侧分开考虑,先考虑左边,如果直线的一个区间旁边的区域有限,那么一定可以找到区间上面一条直线和下面一条直线在所求直线的左侧有交点,这要满足上面直线的斜率大于下面直线,并且他们能覆盖这两条直线与所求直线的交点形成的区间,使得一些连续段区间的左侧为有限区域,那么可以对其他直线从下往上加入,每加入一条直线就找到最下面的并且斜率小于他的直线,然后把对应交点形成的区间覆盖,这些直线可以单调栈维护,区间覆盖可以差分解决.右边同理,把大于小于反过来就行.最后看每一段是否在两边都被覆盖即可

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<vector>
#include<cmath>
#include<ctime>
#include<queue>
#include<map>
#include<set>
#define LL long long
#define db double using namespace std;
const int N=1e5+10;
const db pi=acos(-1),eps=1e-10;
int rd()
{
int x=0,w=1;char ch=0;
while(ch<'0'||ch>'9'){if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
struct point
{
db x,y;
point(){}
point(db nx,db ny){x=nx,y=ny;}
void rot(db cta)
{
db xx=x,yy=y;
x=cos(cta)*xx-sin(cta)*yy,y=cos(cta)*yy+sin(cta)*xx;
}
point operator - (const point &bb) const {return point(x-bb.x,y-bb.y);}
db operator * (const point &bb) const {return x*bb.y-y*bb.x;}
}a[N][2];
struct line
{
db k,b;
line(){}
line(point xx,point yy)
{
k=(xx.y-yy.y)/(xx.x-yy.x);
b=xx.y-k*xx.x;
}
bool operator < (const line &bb) const {return b<bb.b;}
}b[N];
int n,cf[N],c2[N],st[N],tp,an[N],ta; int main()
{
n=rd();
for(int i=1;i<=n+1;++i)
{
int x=rd(),y=rd();
a[i][0]=point(x,y);
x=rd(),y=rd();
a[i][1]=point(x,y);
}
if(a[n+1][0].x>a[n+1][1].x) swap(a[n+1][0],a[n+1][1]);
point dtp(a[n+1][0].x,a[n+1][0].y);
for(int i=1;i<=n+1;++i)
a[i][0]=a[i][0]-dtp,a[i][1]=a[i][1]-dtp;
db cta=pi/2-atan2(a[n+1][1].y,a[n+1][1].x);
for(int i=1;i<=n+1;++i)
a[i][0].rot(cta),a[i][1].rot(cta);
for(int i=1;i<=n;++i)
b[i]=line(a[i][0],a[i][1]);
sort(b+1,b+n+1);
tp=0;
for(int i=1;i<=n;++i)
{
int l=1,r=tp,z=0;
while(l<=r)
{
int mid=(l+r)>>1;
if(b[st[mid]].k<b[i].k-eps) z=mid,r=mid-1;
else l=mid+1;
}
if(z) ++cf[st[z]],--cf[i];
if(!tp||b[st[tp]].k>b[i].k+eps) st[++tp]=i;
}
tp=0;
for(int i=1;i<=n;++i)
{
int l=1,r=tp,z=0;
while(l<=r)
{
int mid=(l+r)>>1;
if(b[st[mid]].k>b[i].k+eps) z=mid,r=mid-1;
else l=mid+1;
}
if(z) ++c2[st[z]],--c2[i];
if(!tp||b[st[tp]].k<b[i].k-eps) st[++tp]=i;
}
an[++ta]=0;
for(int i=1;i<n;++i)
{
cf[i]+=cf[i-1],c2[i]+=c2[i-1];
an[++ta]=cf[i]>0&&c2[i]>0;
}
an[++ta]=0;
for(int i=1;i<=ta;++i) printf("%d",an[i]);
return 0;
}

uoj #242【UR #16】破坏蛋糕的更多相关文章

  1. [UOJ UR#16]破坏发射台

    来自FallDream的博客,未经允许,请勿转载,谢谢. 传送门 先考虑n是奇数的情况,很容易想到一个dp,f[i][0/1]表示转移到第i个数,第i个数是不是第一个数的方案数,然后用矩阵乘法优化一下 ...

  2. 【UOJ#242】【UR#16】破坏蛋糕(计算几何)

    [UOJ#242][UR#16]破坏蛋糕(计算几何) 题面 UOJ 题解 为了方便,我们假定最后一条直线是从上往下穿过来的,比如说把它当成坐标系的\(y\)轴. 于是我们可以处理出所有交点,然后把它们 ...

  3. UOJ 241. 【UR #16】破坏发射台 [矩阵乘法]

    UOJ 241. [UR #16]破坏发射台 题意:长度为 n 的环,每个点染色,有 m 种颜色,要求相邻相对不能同色,求方案数.(定义两个点相对为去掉这两个点后环能被分成相同大小的两段) 只想到一个 ...

  4. A. 【UR #16】破坏发射台

    题解: 首先看n是偶数的 那么就是不需要满足对面这个性质的 这样就可以dp了 f[i][0/1]表示dp到第i位,当前数等于或不等于第一位的方案数 然后显然可以用矩阵优化 再考虑n为奇数 用一样的思路 ...

  5. UOJ 【UR #5】怎样跑得更快

    [UOJ#62]怎样跑得更快 题面 这个题让人有高斯消元的冲动,但肯定是不行的. 这个题算是莫比乌斯反演的一个非常巧妙的应用(不看题解不会做). 套路1: 因为\(b(i)\)能表达成一系列\(x(i ...

  6. UOJ #22 UR #1 外星人

    LINK:#22. UR #1 外星人 给出n个正整数数 一个初值x x要逐个对这些数字取模 问怎样排列使得最终结果最大 使结果最大的方案数又多少种? n<=1000,x<=5000. 考 ...

  7. UOJ.52.[UR #4]元旦激光炮(交互 思路)

    题目链接 \(Description\) 交互库中有三个排好序的,长度分别为\(n_a,n_b,n_c\)的数组\(a,b,c\).你需要求出所有元素中第\(k\)小的数.你可以调用至多\(100\) ...

  8. UOJ【UR #12】实验室外的攻防战

    题意: 给出一个排列$A$,问是否能够经过以下若干次变换变为排列$B$ 变换:若${A_i> A_i+1}$,可以${swap(A_i,A_i+1)}$ 考虑一个数字从A排列到B排列连出来的路径 ...

  9. 超实用的HTML代码段(赵荣娇)

    第1章 创建HTML文档 11.1 HTML文档的基本结构 2 <html> <head> <title>Title of page</title> & ...

随机推荐

  1. dependencies和devDependencies的区别?

    当我们项目需要下载一个模块的时候,我们安装npm包(在项目目录下面npm install module_name)的时候,很多时候我们会在后面加上–save-dev 或 –save.这两个参数代表什么 ...

  2. 理解PyTorch的自动微分机制

    参考Getting Started with PyTorch Part 1: Understanding how Automatic Differentiation works 非常好的文章,讲解的非 ...

  3. 前端23种js设计模式中参见的7种设计模式的学习

    创建型设计模式是一类处理对象创建的设计模式,通过某种方式控制对象的创建来避免基本对象创建时可能导致设计上的问题或增加设计上的复杂度. 1)工厂模式 class Product { constructo ...

  4. spring 手动注册bean

    //将applicationContext转换为ConfigurableApplicationContext ConfigurableApplicationContext configurableAp ...

  5. MongoDB4和MysSQL5.7的读/写和事务处理速度简单对比

    系统环境: Ubuntu 18.04 数据库 MysSQL5.7/MongoDB4.0 插入的数据为随机生产,不重复. MySQL使用的连接库是 sqlalchemyMongoDB使用的连接库是pym ...

  6. scrum例会报告+燃尽图01

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2019fall/homework/9954 一.小组情况 组长:贺敬文组员:彭思雨 王志文 位军营 徐丽君队名 ...

  7. leetcode 123. 买卖股票的最佳时机 III

    使用动态规划的解法,空间复杂度O(2*2)如果交易k次则为O(2*k),时间复杂度O(2n),交易k次为O(n*k), 因此本题实际上可以退化为买卖一次的情况:去掉buy2和sell2,即leetco ...

  8. redis-主从复制、读写分离

    1.为什么要主从复制(一主多仆),读写分离:redis在作为缓存的时候,随着数据的不断增加,是有可能出现宕机的,这时候就出现了“单点故障”,解决方案就是进行主从复制,读写分离. 原理图:Master是 ...

  9. win10安装mysql-最简单教程

    工具下载地址 链接: https://pan.baidu.com/s/1XL2wUDrcd9NpT8NOcXoDTQ 提取码: vu34 下载好之后解压. 在目录D:\Program Files\my ...

  10. Chrome OS支持在窗口中运行Linux了!!!

    借助Crouton Chrome扩展,Chrome OS可以在窗口中运行Linux了.在使用该扩展之前,你需要先将自己的Chromebook设置成开发者模式(Develeper Mode). 此前,C ...