QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#740558#9156. 百万富翁robertfan0 9ms21020kbC++141.6kb2024-11-13 10:29:492024-11-13 10:29:51

Judging History

你现在查看的是最新测评结果

  • [2024-11-13 10:29:51]
  • 评测
  • 测评结果:0
  • 用时:9ms
  • 内存:21020kb
  • [2024-11-13 10:29:49]
  • 提交

answer

#include <bits/stdc++.h>
#include "richest.h"
using namespace std;
int mp[8]={1,183,3472,20832,62500,125000,250000,500000};
int ok[1000006];
int dfs(vector<int>all,int t,int s){
    if(all.size()==1){
        return all[0];
    }
    vector<int>num;
    int cnt=0;
    vector<int>ve;
    for(int i=0;i<all.size();i++){
        cnt++;
        num.push_back(all[i]);
        if(cnt==mp[t-1]){
            ve.push_back(dfs(num,t,s));
            num.clear();
            cnt=0;
        }
    }
    if(num.size()){
        ve.push_back(dfs(num,t-1,s));
    }
    int len=ve.size();
    if(len==1){
        return ve[0];
    }
    vector<int>a,b;
    for(int i=0;i<len;i++){
        for(int j=i+1;j<len;j++){
            a.push_back(ve[i]);
            b.push_back(ve[j]);
        }
    }
    vector<int>c=ask(a,b);
    for(int i=0;i<len;i++){
        ok[c[i]]++;
    }
    int ans;
    for(int i=0;i<len;i++){
        if(ok[ve[i]]==len-1){
            ans= ve[i];
        }
    }for(int i=0;i<len;i++){
        ok[c[i]]--;
    }
    return ans;
}
int richest(int N,int T,int S){
    memset(ok,0,sizeof(ok));
    vector<int>all;
    for(int i=1;i<=N;i++){
        all.push_back(i);
    }
    if(N==1000){
        int len=N;
        vector<int>a,b;
    for(int i=0;i<len;i++){
        for(int j=i+1;j<len;j++){
            a.push_back(all[i]);
            b.push_back(all[j]);
        }
    }
    vector<int>c=ask(a,b);
    for(int i=0;i<len;i++){
        ok[c[i]]++;
    }
    for(int i=0;i<len;i++){
        if(ok[all[i]]==len-1){
            return all[i];
        }
    }
    }
    return dfs(all,T,S);
}

Details

Tip: Click on the bar to expand more detailed information

Pretests

Pretest #1:

score: 0
Wrong Answer
time: 4ms
memory: 21020kb

input:

1000 1 499500 957319859

output:

Index out of bounds
9775460264716263939
0.000000
6906350380861515327

result:

points 0.0 Index out of bounds

Pretest #2:

score: 0
Memory Limit Exceeded

input:

1000000 20 2000000 29091473

output:

Unauthorized output

result:



Final Tests

Test #1:

score: 0
Wrong Answer
time: 9ms
memory: 19872kb

input:

1000 1 499500 957319857

output:

Index out of bounds
9775460264716263939
0.000000
6906350380861515327

result:

points 0.0 Index out of bounds

Test #2:

score: 0
Memory Limit Exceeded

input:

1000000 20 2000000 29091471

output:

Unauthorized output

result: