QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#790781#6525. New HousesDangXWA 77ms3660kbC++201.7kb2024-11-28 15:21:452024-11-28 15:21:46

Judging History

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

  • [2024-11-28 15:21:46]
  • 评测
  • 测评结果:WA
  • 用时:77ms
  • 内存:3660kb
  • [2024-11-28 15:21:45]
  • 提交

answer

#include <bits/stdc++.h>
#define int long long
#define endl "\n"
using namespace std;
const int mod = 1e9 + 7;
struct node
{
    int a;
    int b;
    int c;
} s[1000005];
bool cmp(node A, node B)
{
    return A.c < B.c;
}
signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);

    int T;
    cin >> T;
    while (T--)
    {
        int n, m;
        cin >> n >> m;
        int k;
        if (((m + 1) / 2) >= n)
            k = n;
        else
            k = m - n;
        for (int i = 1; i <= n; i++)
        {
            cin >> s[i].a >> s[i].b;
            s[i].c = s[i].a - s[i].b;
        }
        sort(s + 1, s + n + 1, cmp);
        if (n - k <= 1)
        {
            int temp1 = s[n].a + s[n - 1].a;
            int temp2 = 0;
            for (int i = 1; i <= n - 2; i++)
            {

                if (s[i].c < 0)
                {
                    temp1 += s[i].b;
                }
                else
                {
                    temp1 += s[i].a;
                }
            }
            for (int i = 1; i <= n; i++)
            {
                temp2 += s[i].b;
            }
            cout << max(temp1, temp2) << endl;
        }
        else
        {
            int sum = 0;
            for (int i = 1; i <= n; i++)
            {
                if (s[i].c < 0 && k > 0)
                {
                    sum += s[i].b;
                    k--;
                }
                else
                {
                    sum += s[i].a;
                }
            }
            cout << sum << endl;
        }
    }

    return 0;

} /*Orz Orz Orz ACACAC*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

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: 77ms
memory: 3660kb

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'