QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#138353#6525. New Houseskingstonduy#WA 89ms3552kbC++231.4kb2023-08-11 16:11:032023-08-11 16:11:03

Judging History

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

  • [2023-08-11 16:11:03]
  • 评测
  • 测评结果:WA
  • 用时:89ms
  • 内存:3552kb
  • [2023-08-11 16:11:03]
  • 提交

answer

#include<bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>

#define openr() freopen("input.txt","r",stdin)
#define openw() freopen("output.txt","w",stdout)
#define mp make_pair
#define fi first
#define se second
#define int long long int

using namespace std;
using namespace __gnu_pbds;
template <typename T>
using ordered_set=tree<T,null_type,less<T>,rb_tree_tag,tree_order_statistics_node_update>;

const int inf = 1e18;
const int maxn = 2e6;
const int mod = 1e9 + 7;

/*
    find_by_order(k)
    order_of_key(k)
*/




void show() {
    int n,m;    cin>>n>>m;
    deque<int>v;
    int sum = 0;
    int res=0;
    for(int i=1;i<=n;i++) {
        int temp1,temp2;
        cin>>temp1>>temp2;
        v.push_back(temp1-temp2);
        res += temp1;
    }
    sum= res;
    sort(v.begin(), v.end());
    for(int i=1;i<n;i++) {
        // i flip
        // i*2 spaces
        if(i*2 + n-i <= m && (n-i) != 1) {
            sum-= v.front();
            v.pop_front();
            res= max(res, sum);
        }
    }
    if(n*2 -1 <= m) {
        while(v.size()) {
            sum -= v.front();
            v.pop_front();
        }
        res= max(res, sum);
    }
    cout<<res;
}

int32_t main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    //openr();
    int tc; cin>>tc;
    while(tc--) {
        show();
        cout<<"\n";
    }
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

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: 89ms
memory: 3552kb

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'