QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#138429#6525. New Housesmeomeo#WA 76ms3548kbC++141.2kb2023-08-11 18:17:032023-08-11 18:17:11

Judging History

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

  • [2023-08-11 18:17:11]
  • 评测
  • 测评结果:WA
  • 用时:76ms
  • 内存:3548kb
  • [2023-08-11 18:17:03]
  • 提交

answer

#include<bits/stdc++.h>
#define int long long

using namespace std;

bool cmp(pair<int, int> &A, pair<int, int> &B) {
    return (A.second - A.first) < (B.second - B.first);
}

signed main(){
    ios::sync_with_stdio(0); cin.tie(0);
//    freopen("input.txt","r",stdin);
    //freopen("output.txt","w",stdout);

    int t;

    cin >> t;

    while (t--) {
        int n, m;

        cin >> n >> m;

        int k = m - n;

        int s = 0, s2 = 0;

        vector<pair<int, int>> a(n);

        for (auto &[u, v]: a) {
            cin >> u >> v;
            s += u;
            s2 += v;
        }

        sort(a.begin(), a.end(), cmp);

        int res = s;

        while (k) {
            if (a.size() == 2) {
                s = max(s, s + a[0].second + a[1].second - a[0].first - a[1].first);
                break;
            }

            if (a.size() == 0) break;
            if (a.back().second - a.back().first <= 0) break;
            s += a.back().second - a.back().first;
            res = max(res, s);
            a.pop_back();
            k -= 1;
        }

        cout << s << "\n";
    }
    return 0;
}

详细

Test #1:

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

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: 76ms
memory: 3548kb

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
2031887824
2044500908
1857678917
6815058419
2237593918
6646615756
5638337819
3690874076
5497726904
5513905900
5404435094
4705403467
2411992217
3430587752
5098767681
3921151709
1445672728
2692878616
3833748807
2716183054
850381192
6464787173
8839...

result:

wrong answer 26th numbers differ - expected: '974485573', found: '850381192'