51Nod1100 斜率最大
平面上有N个点,任意2个点确定一条直线,求出所有这些直线中,斜率最大的那条直线所通过的两个点。
(点的编号为1-N,如果有多条直线斜率相等,则输出所有结果,按照点的X轴坐标排序,正序输出。数据中所有点的X轴坐标均不相等,且点坐标为随机。)
Input
第1行,一个数N,N为点的数量。(2 <= N <= 10000) 第2 - N + 1行:具体N个点的坐标,X Y均为整数(-10^9 <= X,Y <= 10^9)
Output
每行2个数,中间用空格分隔。分别是起点编号和终点编号(起点的X轴坐标 < 终点的X轴坐标)
Input示例
5 1 2 6 8 4 4 5 4 2 3
Output示例
4 2
斜率最大的直线经过的两个点一定相邻。
1 #include <iostream> 2 #include <algorithm> 3 using namespace std; 4 struct node 5 { 6 int num; 7 int x,y; 8 }; 9 bool operator<(const node &n1,const node &n2) 10 { 11 return n1.x<n2.x; 12 } 13 node a[10005]; 14 int main() 15 { 16 int n; 17 ios::sync_with_stdio(false); 18 cin>>n; 19 for(int i=0;i<n;i++) 20 { 21 cin>>a[i].x; 22 cin>>a[i].y; 23 a[i].num=i+1; 24 } 25 sort(a,a+n); 26 int ans_s,ans_e; 27 double k=0; 28 for(int i=0;i<n-1;i++) 29 { 30 double t=(a[i+1].y-a[i].y)/(a[i+1].x-a[i].x); 31 if(t>k) 32 { 33 k=t; 34 ans_s=a[i].num; 35 ans_e=a[i+1].num; 36 } 37 } 38 cout<<ans_s<<" "<<ans_e<<endl; 39 return 0; 40 }