QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#397558#6525. New HousesiwewWA 91ms3784kbC++201.1kb2024-04-24 12:35:042024-04-24 12:35:05

Judging History

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

  • [2024-04-24 12:35:05]
  • 评测
  • 测评结果:WA
  • 用时:91ms
  • 内存:3784kb
  • [2024-04-24 12:35:04]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;

#define int long long

typedef long long ll;

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);

    int T;
    cin >> T;
    while(T -- ) {
        int n, m;
        cin >> n >> m;
        vector<array<int, 3>> arr(n);
        for(int i = 0; i < n; i ++ ) {
            cin >> arr[i][0] >> arr[i][1];
            arr[i][2] = arr[i][1] - arr[i][0];
        }
        sort(arr.begin(), arr.end(), [&](array<int, 3> x, array<int, 3> y) {
            return x[2] > y[2];
        });

        vector<ll> sufa(n + 1, 0);
        for(int i = n - 1; i >= 0; i -- ) sufa[i] = sufa[i + 1] + arr[i][0];

        ll ans = sufa[0], sumb = 0;
        for(int i = 0; i < n; i ++ ) {
            sumb += arr[i][1];
            if(arr[i][2] <= 0) break;
            if(2 * (i + 1) + n - i - 1 <= m && n - i - 1 >= 2) {
                ans = max(ans, sumb + sufa[i + 1]);
            }
        }
        if(n + n - 1 <= m) ans = max(ans, sumb);
        cout << ans << '\n';
    }
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3784kb

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: 91ms
memory: 3564kb

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
974485573
6464787173
8839...

result:

wrong answer 51st numbers differ - expected: '755018141', found: '956338726'