• [题解]Magic Line-计算几何(2019牛客多校第三场H题)


    题目链接:https://ac.nowcoder.com/acm/contest/883/H


    题意:

    给你偶数个点的坐标,找出一条直线将这n个点分成数量相等的两部分

    并在这条直线上取不同的两个点,表示这条直线

    思路:

    看见这题的第一反应是,先定一个相对这些点无限远的定点

    然后取扫一遍,取一个其中一个点,找到一条能将这些点分成m个和m+1个点

    最后将斜率微微倾斜,在直线上再取一点即可

    最后疯狂WA,不知道是算法问题还是代码问题

    听了大佬的讲解,发现自己真的蠢

    最后的做法:

    将这n个点按x坐标从小到大排序,x坐标相同时按y坐标从小到大排序

    这样就能找到中间偏左的一个点p(x0,y0),取一条竖直直线x=x0

    然后将这条竖直直线,以点p为中心逆时针旋转一点点

    设答案两点a(x1,y2),b(x2,y2),令x1=x0-1,x2=x0+1,y1=y0+1000000,y2=y0-1000000 就可以实现

    这样就能将这些点分为成m个和m+1个点

    最后保持a点不动,将b点上移一个单位长度 y2=y2+1

    就能使点p也落在直线下面,成功分成数量相等的两堆

    再次感叹一下自己好捞qaq

     1 #include <bits/stdc++.h>
     2 using namespace std;
     3 typedef long long ll;
     4 #define e 990000000
     5 
     6 struct point{
     7     int x,y;
     8 }p[1006];
     9 
    10 bool cmp(point a,point b){
    11     if(a.x==b.x)
    12         return a.y<b.y;
    13     return a.x<b.x; 
    14 } 
    15 
    16 int main()
    17 {
    18     int n,m,t,x1,x2,y1,y2;
    19     cin>>t;
    20     while(t--){
    21         cin>>n;
    22         for(int i=0;i<n;i++)
    23             cin>>p[i].x>>p[i].y;
    24         sort(p,p+n,cmp);
    25         int m=n/2-1;
    26         x1=p[m].x-1,x2=p[m].x+1,y1=p[m].y+e,y2=p[m].y-e+1;
    27         printf("%d %d %d %d
    ",x1,y1,x2,y2);
    28     }
    29     return 0; 
    30 }
    正因为是最弱,所以才理解智慧之强
  • 相关阅读:
    文件上传之前先进行预览
    代码规范
    ESLint 配置文件 .eslintrc 示例及说明
    JQ ajax全局事件 (个人学习笔记)
    JQ ajax (个人学习笔记)
    js 滚动加载图片(懒加载)实现原理 (个人学习笔记)
    js 正则 (个人学习笔记)
    js 理解闭包 (个人学习笔记)
    js 改变this指向的几种方法(个人学习笔记)
    js 理解this指向(个人学习笔记)
  • 原文地址:https://www.cnblogs.com/Yanick/p/11249740.html
Copyright © 2020-2023  润新知