• 题面描述

    • 在\(xOy\)直角坐标平面上有\(n\)条直线\(L_1,L_2,...,L_n\),若在\(y\)值为正无穷大处往下看,能见到\(L_i\)的某个子线段,则称\(L_i\)为可见的,否则\(L_i\)为被覆盖的.例如,对于直线:\(L_1:y=x; L_2:y=-x; L_3:y=0\)则\(L_1\)和\(L_2\)是可见的,\(L_3\)是被覆盖的.给出\(n\)条直线,表示成\(y=Ax+B\)的形式\((|A|,|B|\leq 5*10^5)\),且\(n\)条直线两两不重合.求出所有可见的直线.
  • 输入格式
    • 第一行为\(N(0 < N < 50000)\),接下来的\(N\)行输入\(A_i,B_i\)
  • 输出格式
    • 从小到大输出可见直线的编号,两两中间用空格隔开,最后一个数字后面也必须有个空格
  • 题解
    • 不难看出该题核心就是对于给定\(n\)条直线,求他们的下凸包
    • 注意有多个\(A_i\)相同的,在压入栈的时候按\(B_i\)从小到大压入,把前面没有被弹出的\(A_x==A_i\)全部弹出
    • 另:前两条直线不能默认直接压进去,因为他们\(A\)可能相等
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int MAXN=5e4+5;
const double eps=1e-8;
struct rec{
double a,b;
int id;
} a[MAXN];
int n;
bool cmp(rec a,rec b){ return fabs(a.a-b.a)<eps?a.b<b.b:a.a<b.a; }
int st[MAXN],top;
struct dt{
double x,y;
};
dt dot(int i,int j){
double x=(a[j].b-a[i].b)/(a[i].a-a[j].a);
double y=a[i].a*x+a[i].b;
return (dt){x,y};
}
int ans[MAXN],cnt;
int main(){
scanf("%d",&n);
for (int i=1;i<=n;i++) scanf("%lf%lf",&a[i].a,&a[i].b),a[i].id=i;
sort(a+1,a+n+1,cmp);
for (int i=1;i<=n;i++){
while (top>=1&&fabs(a[st[top]].a-a[i].a)<eps) top--;
while (top>=2&&dot(st[top-1],st[top]).x>=dot(st[top-1],i).x) top--;
st[++top]=i;
}
for (int i=1;i<=top;i++) ans[cnt++]=a[st[i]].id;
sort(ans,ans+cnt);
for (int i=0;i<cnt;i++) printf("%d ",ans[i]);
printf("\n");
return 0;
}

天助自助者

随机推荐

  1. 编写高质量代码改善C#程序的157个建议——建议13: 为类型输出格式化字符串

    建议13: 为类型输出格式化字符串 有两种方法可以为类型提供格式化的字符串输出.一种是意识到类型会产生格式化字符串输出,于是让类型继承接口IFormattable.这对类型来 说,是一种主动实现的方式 ...

  2. 20169219 SEED SQL注入实验

    实验环境SEED Ubuntu镜像 环境配置 实验需要三样东西,Firefox.apache.phpBB2(镜像中已有): 1.运行Apache Server:只需运行命令sudo service a ...

  3. HackTwelve 为背景添加圆角边框

    1.概要:     ShapeDrawable是一个为UI控件添加特效的好工具.这个技巧适用于那些可以添加背景的控件 2.添加圆角边框其实就是添加的背景那里不是直接添加图片,而是添加一个XML文件即可 ...

  4. log4net工作原理(2)

    上回说道:Repository可以说成基于一个log4net配置节创建的log4net容器,它根据log4net配置节的指示创建其他所有对象(Logger/Appender/Filter/Layout ...

  5. js工具库简单介绍

    javascript mvc的解决方案: angularjs, backbone,underscore, 有空的时候了解一下. 移动端的几个需要了解一下,jq mobile, zepto.knocko ...

  6. 异常:已捕获: "Error creating context 'spring.root': 未将对象引用设置到对象的实例。" (System.Configuration.ConfigurationErrorsException) 捕获到一个 System.Configuration.ConfigurationErrorsException: "Error creating context 'sp

    查看所指定name的context是否注册成功,以后用此容器来获取其中的object. 常见的使用方式: Application_Start中使用ContextRegistry.GetContext( ...

  7. django修改数据库连接

    settings.py DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'domain', 'USER ...

  8. 2. C/C++笔试面试经典题目二

    1. C和C++中struct有什么区别? [参考答案] [解析]C中的struct没有保护行为,没有public,private,protected,内部不能有函数,但可以有函数指针. 2. C++ ...

  9. [转]An STL compliant sorted vector-源码示例

    原文地址:http://www.codeproject.com/Articles/3217/An-STL-compliant-sorted-vector 最近在看sorted vectored的一些东 ...

  10. Phpstudy+WordPress安装详解

    Phpstudy+WordPress安装详解 1.安装phpStudy程序 将下载的phpStudy程序解压到某个分区的根目录中,第一次使用会提示你初始化一下: 之后在主控制界面点击启动即可. php ...