2020 BIT冬训-C++STL K - Anton and Lines CodeForces - 593B
Problem Description
The teacher gave Anton a large geometry homework, but he didn't do it (as usual) as he participated in a regular round on Codeforces.
In the task he was given a set of n lines defined by the equations y = ki·x + bi. It was necessary to determine whether there is at least
one point of intersection of two of these lines, that lays strictly inside the strip between x1 < x2. In other words, is it true that there are 1 ≤ i < j ≤ n and x', y', such that:
- y' = ki * x' + bi, that is, point (x', y') belongs to the line number i;
- y' = kj * x' + bj, that is, point (x', y') belongs to the line number j;
- x1 < x' < x2, that is, point (x', y') lies inside the strip bounded by x1 < x2.
You can't leave Anton in trouble, can you? Write a program that solves the given task.
Input
The first line of the input contains an integer n (2 ≤ n ≤ 100 000) — the number of lines in the task given to Anton.
The second line contains integers x1 and x2 ( - 1 000 000 ≤ x1 < x2 ≤ 1 000 000) defining the strip inside which you need to find a point of intersection of at least two lines.
The following n lines contain integers ki, bi ( - 1 000 000 ≤ ki, bi ≤ 1 000 000) — the descriptions of the lines.
It is guaranteed that all lines are pairwise distinct, that is, for any two i ≠ j it is true that either ki ≠ kj, or bi ≠ bj.
Output
Print "Yes" (without quotes), if there is at least one intersection of two distinct lines, located strictly inside the strip. Otherwise print "No" (without quotes).
Examples
4
1 2
1 2
1 0
0 1
0 2
NO
2
1 3
1 0
-1 3
YES
2
1 3
1 0
0 2
YES
2
1 3
1 0
0 3
NO
这题主要是要开long long,int的话数据会爆导致错误nnd。
还有就是冷静分析区间内相交的性质。(零点存在性定理)
#include<stdio.h> #include<algorithm> using namespace std; pair<__int64,__int64> line[100005]; __int64 n,x1,x2,k,b; int main(){ scanf("%I64d%I64d%I64d",&n,&x1,&x2); for(int i =0;i<n;i++){ scanf("%I64d%I64d",&k,&b); line[i]={k*x1+b,k*x2+b}; } sort(line,line+n); for(int i=1;i<n;i++){ if(line[i-1].second>line[i].second){ printf("YES"); return 0; } } printf("NO"); return 0; }

浙公网安备 33010602011771号