QOJ.ac

QOJ

ID提交记录ID题目HackerOwner结果提交时间测评时间
#1281#814871#9869. Horizon Scanningucup-team3474ucup-team3474Failed.2024-12-14 21:53:162024-12-14 21:53:17

詳細信息

Extra Test:

Invalid Input

input:

1
200000 138621
999994693 999999836
999998543 999998452
999994439 -999999189
999999211 999993178
999990353 999999930
999993309 999990198
999995963 999995078
999997821 999994058
999999071 999995138
999991269 -999997828
999998888 999999260
999993313 999992576
999993483 999996253
999991408 999999167
99...

output:


result:

FAIL Duplicate island found. (test case 1)

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#814871#9869. Horizon Scanningucup-team3474AC ✓117ms44828kbC++202.1kb2024-12-14 21:46:132024-12-14 21:46:14

answer

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll,ll> PII;

const int N=5e5+10,mod=998244353;
const double PI=acos(-1);
int n,m,k,l,b;
typedef struct{
    ll x,y,cnt;
    double jiao;
    ll fz,fm,flag;
}Node;

PII cal(ll x,ll y){
    if(x==0&&y==0) return {0,0};
    else if(x==0){
        if(y>0)
        return {0,1};
        else return {0,-1};
    } 
    else if(y==0){
        if(x>0)
        return {1,0};
        else return {-1,0};
    }else{
        ll gg=__gcd(abs(x),abs(y));
        x/=gg,y/=gg;
        return {x,y};
    }
}

bool cmp(Node &a,Node &b){
    return a.jiao<b.jiao;
}


void __(){
    cin>>n>>m;
    vector<Node> nd;
    map<PII,int> mp;
    for(int i=1;i<=n;i++){
        ll x,y;
        scanf("%lld%lld",&x,&y);
        PII res=cal(x,y);
        mp[res]++;
    }
    int sz=mp.size();
    for(auto [x,y]:mp){

        Node nnd;
        nnd.fz=nnd.x=x.first;
        nnd.fm=nnd.y=x.second;
        nnd.cnt=y;
        double u=x.first,v=sqrtl(x.first*x.first+x.second*x.second);
        if(x.second>0) nnd.jiao=acos(u/v);
        else nnd.jiao=PI*2-acos(u/v);
        nd.push_back(nnd);
        // nd.push_back({x.first,x.second})
    }
    
    for(int i=0;i<sz;i++){
        nd.push_back(nd[i]);
    } 
    for(int i=0;i<sz;i++){
        nd[i+sz].jiao+=PI*2;
    }
    sort(nd.begin(),nd.end(),cmp);
    // for(auto x:nd) cout<<x.jiao<<" "<<x.cnt<<endl;;
    // cout<<endl;
    int j=0,tot=0;
    double ans=0;
    for(int i=0;i<sz;i++){
        // cout<<j<<" "<<tot<<" "<<m+nd[i].cnt<<endl;
        while(j<=i+sz&&tot<m+nd[i].cnt){
            tot+=nd[j].cnt;
            j++;
        }
        // cout<<j<<" "<<tot<<endl;
        ans=max(ans,nd[j-1].jiao-nd[i].jiao);
        tot-=nd[i].cnt;
    }
    printf("%.15f\n",ans);
}



//246748500000

int main(){
    
    // ios::sync_with_stdio(0);
    // cin.tie(0);
    // mi[0]=1;
    // for(int i=1;i<=20;i++) mi[i]=mi[i-1]*3;
    int _=1;
    cin>>_;
    
    for(int i=1;i<=_;i++){
        
        __();
        
    }
    // int x;
    
}