分治

分治做法还不会,以后再补、、、
https://www.luogu.com.cn/problem/P1257
https://www.luogu.com.cn/problem/P1429
https://www.luogu.com.cn/problem/P7883
//随机坐标旋转一定角度,然后按照x或y进行排序,从前往后找k个点即可,k == 5的时候就ac了。。。。。。
//旋转角度公式:  //x'=xcosθ-ysinθ
				//y'=xsinθ+ycosθ
#include<bits/stdc++.h>
using namespace std;

typedef long long ll;
const int N = 2e6+9;

struct Point {
    long double x,y;
}Points[N];

bool operator < (Point a,Point b) {
    if(a.x != b.x) return a.x < b.x;
    return a.y < b.y;
}

long double get_dis(int p,int q) {
    long double dx = Points[p].x - Points[q].x;
    long double dy = Points[p].y - Points[q].y;
    return sqrtl(dx * dx + dy * dy);
}

int main() {
    int n;
    cin >> n;
    for(int i=1; i<=n; i++) {
        long double x,y,x_,y_;
        scanf("%LF%LF",&x,&y);
        x_ = x,y_ = y;
        x = x_ * cosl(1) - y_ * sinl(1),y = x_ * sinl(1) + y_ * cosl(1);
        Points[i] = {x,y};
    }
    sort(Points+1,Points+n+1);
    long double ans = 2e18;
    for(int i=1; i<=n; i++) {
        for(int j=i+1; j<=n && j <= i+5; j++) {
            ans = min(ans,get_dis(i,j));
        }
    }
    printf("%.4LF\n",ans);
    return 0;
}

全部评论

相关推荐

LZStarV:冲就好了,就算真的是字节也冲,面评脏了大不了等三四个月就淡了,而且等到那个时候实力进步了选择还多,何必拘泥于字节
点赞 评论 收藏
分享
10-29 16:42
门头沟学院 Java
1.今天什么国标的公司打电话约面试,还得准备ppt,好麻烦,网上查薪资一般,打算拒了,不面了2.字节又复活了,什么安全开发,也不知道怎么样,面一面试试吧,还是挺想去字节的,但好难,随缘吧所以今天没面试
嵌入式的小白:面试前可以好好准备下 1.看看你投递的岗位的岗位描述,分析下是哪个业务线,同使要罗列他们描述中提到的技术点 2.根据1中的两点准备 3.岗位描述中应该还有语言要求,这个刷刷八股,要是对自己语言能力很有把握,那就不用看这点了 4.找下你简历中项目部分,看有没有和岗位描述中技术点重合的,这种在面试提到项目时,是高概率问题 好好准备,祝你面试顺利
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务