結果

問題 No.5007 Steiner Space Travel
ユーザー HaaHaa
提出日時 2022-07-30 15:25:06
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 965 ms / 1,000 ms
コード長 4,087 bytes
コンパイル時間 2,184 ms
実行使用メモリ 6,952 KB
スコア 7,881,253
最終ジャッジ日時 2022-07-30 15:25:40
合計ジャッジ時間 32,900 ms
ジャッジサーバーID
(参考情報)
judge11 / judge12
純コード判定しない問題か言語
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 932 ms
5,152 KB
testcase_01 AC 912 ms
4,904 KB
testcase_02 AC 907 ms
4,904 KB
testcase_03 AC 905 ms
4,900 KB
testcase_04 AC 916 ms
5,160 KB
testcase_05 AC 931 ms
5,160 KB
testcase_06 AC 907 ms
4,900 KB
testcase_07 AC 910 ms
5,160 KB
testcase_08 AC 965 ms
4,908 KB
testcase_09 AC 910 ms
4,904 KB
testcase_10 AC 933 ms
4,904 KB
testcase_11 AC 907 ms
4,904 KB
testcase_12 AC 908 ms
4,904 KB
testcase_13 AC 907 ms
5,160 KB
testcase_14 AC 916 ms
4,900 KB
testcase_15 AC 923 ms
5,160 KB
testcase_16 AC 911 ms
4,904 KB
testcase_17 AC 932 ms
5,156 KB
testcase_18 AC 934 ms
6,952 KB
testcase_19 AC 910 ms
4,908 KB
testcase_20 AC 934 ms
5,160 KB
testcase_21 AC 918 ms
4,904 KB
testcase_22 AC 911 ms
4,904 KB
testcase_23 AC 917 ms
4,904 KB
testcase_24 AC 908 ms
4,900 KB
testcase_25 AC 934 ms
4,900 KB
testcase_26 AC 906 ms
4,904 KB
testcase_27 AC 914 ms
4,900 KB
testcase_28 AC 911 ms
4,900 KB
testcase_29 AC 913 ms
4,904 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: 関数 ‘void solve()’ 内:
main.cpp:141:18: 警告: structured bindings only available with ‘-std=c++17’ or ‘-std=gnu++17’
  141 |         for(auto [t,r]:ans[i]){
      |                  ^
main.cpp:119:17: 警告: ‘ry’ はこの関数内初期化されずに使用されるかもしれません [-Wmaybe-uninitialized]
  119 |                 if(ry==0){
      |                 ^~

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
#define REP(i,n) for(ll i=0;i<(n);i++)
#define ALL(v) v.begin(),v.end()
template<typename T> bool chmax(T &x, const T &y) {return (x<y)?(x=y,true):false;};
template<typename T> bool chmin(T &x, const T &y) {return (x>y)?(x=y,true):false;};
constexpr ll MOD=998244353;
constexpr ll INF=2e18;

struct Point{
    int x, y;
};

inline int pdist(const Point& p1, const Point& p2){
    return (p1.x-p2.x)*(p1.x-p2.x)+(p1.y-p2.y)*(p1.y-p2.y);
}

const double TL=0.9;
const double T0=8000;
const double T1=10;
double start, T;

int alp=5;
int N, M;
vector<Point> P(100);

Point cog(const set<int>& s){
    int sz=s.size();
    int xsum=0, ysum=0;
    for(auto i:s){
        xsum+=P[i].x;
        ysum+=P[i].y;
    }
    return {xsum/sz,ysum/sz};
}

void input(){
    cin >> N >> M;
    REP(i,N) cin >> P[i].x >> P[i].y;
}

void solve(){
    vector<vector<int>> dist(N,vector<int>(N));
    REP(i,N)REP(j,N) dist[i][j]=pdist(P[i],P[j]);
    vector<int> ord(N);
    iota(ALL(ord),0);
    vector<set<int>> sss(M);
    REP(i,M) sss[i]={ord[i],ord[(i+1)%N]};
    vector<Point> ssp(M);
    REP(i,M) ssp[i]=cog(sss[i]);
    ll cost=0, maxcost=INF;
    REP(i,N) cost+=alp*alp*dist[ord[i]][ord[(i+1)%N]];
    vector<Point> ansssp;
    vector<vector<pair<int,int>>> ans;
    int rcnt=0;
    for(rcnt=0;true;rcnt++){
        int rx, ry, r1, r2;
        rx=rand()%2;
        if(rx!=0){
            r1=rand()%N+1;
            r2=rand()%N+1;
            if(r1>r2) swap(r1,r2);
            reverse(ord.begin()+r1,ord.begin()+r2);
        }
        else{
            ry=rand()%2;
            if(ry==0){
                r1=rand()%M;
                r2=rand()%N;
                if(sss[r1].find(r2)!=sss[r1].end())
                    continue;
                sss[r1].insert(r2);
                ssp[r1]=cog(sss[r1]);
            }
            else{
                r1=rand()%M;
                r2=rand()%N;
                if(sss[r1].size()==2)
                    continue;
                if(sss[r1].find(r2)==sss[r1].end())
                    continue;
                sss[r1].erase(r2);
                ssp[r1]=cog(sss[r1]);
            }
        }
        vector<vector<pair<int,int>>> pans(N);
        ll newcost=0;
        REP(i,N){
            ll mcost=alp*alp*pdist(P[ord[i]],P[ord[(i+1)%N]]);
            pans[i]={{0,ord[i]}};
            REP(j,M)REP(k,M+1){
                if(k==M){
                    if(chmin(mcost,(ll)alp*(pdist(P[ord[i]],ssp[j])+pdist(ssp[j],P[ord[(i+1)%N]])))){
                        pans[i]={{0,ord[i]},{1,j}};
                    }
                }
                else{
                    if(chmin(mcost,(ll)alp*(pdist(P[ord[i]],ssp[j])+pdist(ssp[k],P[ord[(i+1)%N]]))+pdist(ssp[j],ssp[k]))){
                        pans[i]={{0,ord[i]},{1,j},{1,k}};
                    }
                }
            }
            newcost+=mcost;
            if(i==N-1)
                pans[i].push_back({0,0});
        }
        if(chmin(maxcost,newcost)){
            ans=pans;
            ansssp=ssp;
        }
        if(rand()%1000000>exp((newcost-cost)/T)*1e6)
            cost=newcost;
        else{
            if(rx!=0){
                reverse(ord.begin()+r1,ord.begin()+r2);
            }
            else{
                if(ry==0){
                    sss[r1].erase(r2);
                    ssp[r1]=cog(sss[r1]);
                }
                else{
                    sss[r1].insert(r2);
                    ssp[r1]=cog(sss[r1]);
                }
            }
        }  
        if(rcnt%50==0){
            double t=(double)(clock()-start)/CLOCKS_PER_SEC/TL;
            if(t>=1.0)
                break;
            T=pow(T0,(t-0.6)/0.4)*pow(T1,t-0.6);
        }
    }
    REP(i,M) cout << ansssp[i].x << " " << ansssp[i].y << endl;
    int szs=0;
    REP(i,N) szs+=ans[i].size();
    cout << szs << endl;
    REP(i,N){
        for(auto [t,r]:ans[i]){
            cout << t+1 << " " << r+1 << endl;
        }
    }
}

int main(){
    start=clock();
    input();
    solve();
    return 0;
}
0