QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#701331#6525. New Houseslibantian#WA 109ms3840kbC++231.4kb2024-11-02 14:04:372024-11-02 14:04:37

Judging History

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

  • [2024-11-02 14:04:37]
  • 评测
  • 测评结果:WA
  • 用时:109ms
  • 内存:3840kb
  • [2024-11-02 14:04:37]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define INF 0x3f3f3f3f3f3f3f3f
#define pii pair<int,int>
#define fi first
#define se second
#define all(_a) _a.begin(), _a.end()

void solve(){
    int n,m;
    cin>>n>>m;
    int sum=0;
    priority_queue<int>q;
    for(int i=1;i<=n;i++){
        m--;
        int x,y;
        cin>>x>>y;
        sum+=x;
        q.push(y-x);
    }
    int res=-INF;
    res=max(res,sum);
    if(n==1){
        cout<<res<<endl;
        return ;
    }
    if(n==2){
        if(m){
            sum+=q.top();
            q.pop();
            sum+=q.top();
            q.pop();
            res=max(res,sum);
        }
        cout<<res<<endl;
        return ;

    }
    while(q.size()&&m){
        
        if((q.size()==n)||(q.size()==n-1)){
            if(m==0)break;
            sum+=q.top();
            q.pop();
            res=max(res,sum);
            m--;
            continue;
        }
        if(m>=2){
            sum+=q.top();
            q.pop();
            res=max(res,sum);
            m-=2;
            continue;
        }else break;
    }
    cout<<res<<endl;
}
signed main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr), cout.tie(nullptr);
    cout << setiosflags(ios::fixed) << setprecision(15);
    int T;
    T=1;
    cin>>T;
    while(T--)solve();
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3636kb

input:

3
4 5
1 100
100 1
100 1
100 1
2 2
1 10
1 10
2 3
100 50
1 1000

output:

400
2
1050

result:

ok 3 number(s): "400 2 1050"

Test #2:

score: -100
Wrong Answer
time: 109ms
memory: 3840kb

input:

100000
6 11
191141536 365120521
799679686 648574232
102602909 467685128
405440859 796808887
384858152 191995380
433392826 195648471
5 13
831367906 510447872
795639287 575551283
811207605 176441088
240156289 946977042
133416463 721098873
5 5
806744021 699586200
630510306 637827160
49223781 641709297
...

output:

3247545200
4106290713
2653993029
5122532137
5570513606
2072414809
2044500908
1857678917
6815058419
2237593918
6646615756
5393412666
3690874076
5497726904
5513905900
5367943915
4705403467
2411992217
3430587752
4875673031
3921151709
1466967408
2692878616
3833748807
2825163883
850381192
6464787173
8839...

result:

wrong answer 6th numbers differ - expected: '2031887824', found: '2072414809'