这个题乍眼一看好像很简单,然后我就认为u、v、w只要有全部比另外一个人小的就不能win,否则就能win,但是这个思路只对了一半

不能win的结论是正确的,但是win的结论不止排除这一个条件

将这个人与其他人的条件列式

如果都win的话,则满足 x/v+y/u+(k-x-y)/w(i的)<x/v+y/u+(k-x-y)/w(j的)由此构成n条直线(半平面),然后求交,如果有交集,则输出Yes,否则No

#include <stdio.h>
#include <math.h>
#include <algorithm>
using namespace std;
const double eps = 1e-8; struct Point
{
double x,y;
Point(double x=0,double y=0):x(x),y(y) {}
}; typedef Point Vector; Vector operator - (Point A, Point B)
{
return Vector(A.x-B.x, A.y-B.y);
}
struct Line
{
Point p;
Vector v;
double ang;
Line() {}
Line(Point p,Vector v):p(p),v(v)
{
ang=atan2(v.y,v.x);
}
bool operator < (const Line& L) const
{
return ang<L.ang;
}
}; double Cross(Vector A, Vector B)
{
return A.x*B.y - A.y*B.x;
} bool Onleft(Line L, Point p)
{
return Cross(L.v, p-L.p)>0;
} Point GetIntersection(Line a, Line b)
{
Vector u = a.p-b.p;
double t = Cross(b.v, u)/Cross(a.v, b.v);
return Point(a.p.x+a.v.x*t, a.p.y+a.v.y*t);
} int BPMJ(Line *L, int n, Point *poly)
{
sort(L,L+n);
int first,last;
Point *p = new Point[n];
Line *q = new Line[n];
q[first=last=0] = L[0];
for(int i=1; i<n; i++)
{
while(first<last && !Onleft(L[i],p[last-1]))last--;
while(first<last && !Onleft(L[i],p[first]))first++;
q[++last] = L[i];
if(fabs(Cross(q[last].v,q[last-1].v))<eps)
{
last--;
if(Onleft(q[last], L[i].p))q[last] = L[i];
}
if(first<last) p[last-1] = GetIntersection(q[last-1], q[last]);
}
while(first<last && !Onleft(q[first], p[last-1])) last--;
if(last-first<=1)return 0;
p[last] = GetIntersection(q[last], q[first]);
int m = 0;
for(int i=first; i<=last; i++)
poly[m++] = p[i];
return m;
} double k=10000.0;
int u[110],v[110],w[110];
Point poly[110];
Line L[110]; int main()
{
int n;
while(scanf("%d",&n)==1)
{
for(int i=0; i<n; i++)
{
scanf("%d%d%d",&u[i],&v[i],&w[i]);
}
for(int i=0; i<n; i++)
{
int f=0;
for(int j=0; j<n; j++)
{
if(j!=i && u[i]<=u[j] && v[i]<=v[j] && w[i]<=w[j])
{
f=1;
break;
}
}
if(f==1)
printf("No\n");
else
{
Point p;
int ct=0;
for(int j=0; j<n; j++)
{
if(j!=i && u[i]>=u[j] && v[i]>=v[j] && w[i]>=w[j])
continue;
else if(j!=i)
{
double A=k/v[j]-k/v[i]-k/w[j]+k/w[i];
double B=k/u[j]-k/u[i]-k/w[j]+k/w[i];
double C=k/w[j]-k/w[i];
if(fabs(A)>fabs(B))
p=Point(-C/A,0);
else
p=Point(0,-C/B);
Vector v(B,-A);
L[ct++] = Line(p,v);
}
}
L[ct++] = Line(Point(0,0), Vector(0,-1));
L[ct++] = Line(Point(0,0), Vector(1,0));
L[ct++] = Line(Point(0,1), Vector(-1,1));
if(BPMJ(L,ct,poly))printf("Yes\n");
else printf("No\n");
}
}
}
return 0;
}

URAL 1062 - Triathlon(半平面交)的更多相关文章

  1. POJ 1755 Triathlon [半平面交 线性规划]

    Triathlon Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6912   Accepted: 1790 Descrip ...

  2. LA 2218 Triathlon(半平面交)

    Triathlon [题目链接]Triathlon [题目类型]半平面交 &题解: 做了2道了,感觉好像套路,都是二分答案,判断半平面交是否为空. 还有刘汝佳的代码总是写const +& ...

  3. LA2218 Triathlon /// 半平面交 oj22648

    题目大意: 铁人三项分连续三段:游泳 自行车 赛跑 已知各选手在每个单项中的速度v[i],u[i],w[i] 设计每个单项的长度 可以让某个特定的选手获胜 判断哪些选手有可能获得冠军 输出n行 有可能 ...

  4. POJ 1755 Triathlon (半平面交)

    Triathlon Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4733   Accepted: 1166 Descrip ...

  5. POJ 1755 Triathlon(线性规划の半平面交)

    Description Triathlon is an athletic contest consisting of three consecutive sections that should be ...

  6. LA 2218 (半平面交) Triathlon

    题意: 有n个选手,铁人三项有连续的三段,对于每段场地选手i分别以vi, ui 和 wi匀速通过. 对于每个选手,问能否通过调整每种赛道的长度使得他成为冠军(不能并列). 分析: 粗一看,这不像一道计 ...

  7. poj 1755 半平面交+不等式

    Triathlon Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6461   Accepted: 1643 Descrip ...

  8. 【POJ 3525】Most Distant Point from the Sea(直线平移、半平面交)

    按逆时针顺序给出n个点,求它们组成的多边形的最大内切圆半径. 二分这个半径,将所有直线向多边形中心平移r距离,如果半平面交不存在那么r大了,否则r小了. 平移直线就是对于向量ab,因为是逆时针的,向中 ...

  9. 【BZOJ-2618】凸多边形 计算几何 + 半平面交 + 增量法 + 三角剖分

    2618: [Cqoi2006]凸多边形 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 959  Solved: 489[Submit][Status] ...

随机推荐

  1. 为什么selenium定位不到元素

    在做web应用的自动化测试时,定位元素是必不可少的,这个过程经常会碰到定位不到元素的情况,一般可以从以下几个方面着手解决: 1.Frame/Iframe原因定位不到元素: 这个是最常见的原因,首先要理 ...

  2. Python环境搭建中解决C编译的问题

    下载必要文件 Python Microsoft Visual C++ Compiler for Python 2.7 setuptools 安装Python 安装VCForPython27 在命令行下 ...

  3. 编程思想—面向切面编程(AOP)

    谈到面向切面的编程,我们很容易关联到面向对象编程(OOP).个人对这两种编程方式的解释为:两种编程思想只是站在编程的角度问题. OOP注重的是对象,怎么对对象行为和方法的抽象.如何封装一个具有完整属性 ...

  4. C#与C++的几个不同之处知识点

    1.索引器 索引器是C#自创的内容,这是C++当中没有的内容,所以做一次笔记. 索引器是用于书写一个可以通过使用[]想数组一样直接访问集合元素的方法.我们只需要指定待访问实例或元素的索引.索引器的语法 ...

  5. mvc4 to mvc5 and EF5 to EF6

    今天把 后台的mvc 升级到了mvc5和ef6 .出错很正常. 下面是一些错误信息. [A]System.Web.WebPages.Razor.Configuration.HostSection 无法 ...

  6. [BZOJ 2127] happiness 【最小割】

    题目链接:BZOJ - 2127 题目分析 首先,每个人要么学文科,要么学理科,所以可以想到是一个最小割模型. 我们就确定一个人如果和 S 相连就是学文,如果和 T 相连就是学理. 那么我们再来确定建 ...

  7. Warm up 2

    hdu4619:http://acm.hdu.edu.cn/showproblem.php?pid=4619 题意:题目大意:给你两种纸牌 ,一种水平放置共有n张 ,一种竖直放置共有m张.水平放置的纸 ...

  8. Occupy Cities

    hdu4606:http://acm.hdu.edu.cn/showproblem.php?pid=4606 题意:在一个二维坐标系中,有n个城市,坐标给出来了,然后有p个士兵要去占领这n个城市,但是 ...

  9. 严重推荐一个免费开源数据库建模工具软件 --OpenSystemArchitect 4.0

    嘿嘿,对于我这样的新手,这个工具还是很令人兴奋的. 真的是术业有专攻啊.关键还是免费开源 EXCEL,VISO,PPT,PS,CD,FREEHAND不是不可以,只是.人家还是专业点,方便点.. Ope ...

  10. 如何通过js使搜索关键词高亮

    给你推荐通过jquery来实现高亮关键词.jquery.textSearch-1.0.js代码: (function($){ $.fn.textSearch =function(str,options ...