关于第二篇题解的一点疑问
查看原帖
关于第二篇题解的一点疑问
332781
roguelxx楼主2020/4/30 17:11
#include<bits/stdc++.h>
using namespace std;
inline int dist(int x1,int y1,int x2,int y2){return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);}
//被丧心病狂的我疯狂压行的计算两点距离的函数
struct Jack{
    int l1,l2;
}f[110000];
inline bool cmp(const Jack &a,const Jack &b){return a.l1<b.l1;}
//压行*2(这叫做状态压缩好不好??)
//相对于一号系统进行排序,将大的放到后面去
int main( ){
    int n,i,j,k,x1,x2,y1,y2,a,b;
    std::ios::sync_with_stdio(false);
    cin>>x1>>y1>>x2>>y2;
    cin>>n;
    for(i=1;i<=n;i++){
        cin>>a>>b;
        f[i].l1=dist(x1,y1,a,b);
        f[i].l2=dist(x2,y2,a,b);
    }
    sort(f+1,f+n+1,cmp);
    //STL就是棒
    int ans=f[n].l1,hei=-1;
    //因为将一号系统设置为离它最远的一个便已经能拦截所有导弹了
    for(i=n-1;i>=1;i--){
        hei=max(hei,f[i+1].l2);
        ans=min(ans,hei+f[i].l1);
    }
    cout<<ans<<endl;
}

这是第二篇题解的代码。好像没有考虑所有导弹都由二号系统拦截的情况?举个例子:

0 0 2 0
1
2 0

正解应该是0吧,如果按照题解的思路,最后会得到4。 不知道我的理解有没有错,大佬们帮忙康康~

2020/4/30 17:11
加载中...