QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#246426#7678. The GamefAKeZero#WA 1ms5732kbC++172.5kb2023-11-10 20:13:232023-11-10 20:13:25

Judging History

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

  • [2023-11-10 20:13:25]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:5732kb
  • [2023-11-10 20:13:23]
  • 提交

answer

#include <bits/stdc++.h>

template<class _Tp = int>
_Tp read() {
  _Tp ret = 0;
  char ch = getchar(), sgn = 0;
  while (!isdigit(ch)) sgn |= ch == '-', ch = getchar();
  while (isdigit(ch)) ret = ret * 10 + ch - '0', ch = getchar();
  return sgn ? -ret : ret;
}

const int kMaxN = 3e5 + 5;
int n, m, L;
long long dis;
int a[kMaxN], b[kMaxN];
std::vector<int> ans;

void clear() {

}
bool solve() {
  ans.clear();
  std::multiset<int> S;
  for (int i = m + 1; i <= n; i++)
    S.insert(a[i]);
  int x = m, y = m;
  while (x && a[x] == a[m]) x--;
  x = m - x;
  while (y <= n && a[y] == a[m]) y++;
  y = y - m - 1;
  int am = a[m];
  int r = L - dis;
  while (r > 0) {
    // fprintf(stderr, "ROUND\n");
    if (S.empty())
      return false;
    int c = *S.begin();
    if (c == b[m])
      return false;
    if (c == am) {
    // qiong tu mo lu le
    // cong y li xi sheng x ge am
      // printf("? x%d y%d r%d r+dis%d \n", x, y, r, r + dis);
      if (y < r + dis || x > y)
        return false;
      else {
        for (int i = 1; i <= x; i++)
          ans.push_back(am);
        for (int i = m - x + 1; i <= m; i++)
          a[i]++;
        for (int i = 1; i <= x; i++)
          S.erase(S.begin());
        am++;
      }
      continue;
    }
    ans.push_back(c);
    S.erase(S.begin());
    S.insert(c + 1);
    S.erase(S.begin());
    r--;
  }
  for (int i = 1; i <= m; i++)
    while (a[i] < b[i])
      ans.push_back(a[i]), a[i]++;
  // print_ans();
  // assert(ans.size() == m - n);
  return true;
}


int main() {
  int T = read();
  while (T--) {
    n = read(), m = read();
    L = n - m;
    for (int i = 1; i <= n; i++)
      a[i] = read();
    for (int i = 1; i <= m; i++)
      b[i] = read();
    std::sort(a + 1, a + n + 1, std::greater<int>());
    std::sort(b + 1, b + m + 1, std::greater<int>());
    dis = 0;
    for (int i = 1; i <= m; i++) {
      if (a[i] > b[i]) {
        puts("-1");
        goto end_of_loop;
      }
      dis += b[i] - a[i];
    }
    // fprintf(stderr, "dis %d?\n", dis);
    if (dis > L) {
      puts("-1");
      goto end_of_loop;
    } 
    if (solve()) {
      printf("%d\n", L);
      for (auto i : ans)
        printf("%d ", i);
      puts("");
    } else 
      puts("-1");
    end_of_loop:
      clear();
  }
}

/*
6
5 3
1 2 2 3 3
2 3 4
4 2
1 2 2 4
2 4
5 2
2 3 3 4 4
5 5
6 1
1 1 1 1 1 1
4
4 2
1 1 1 2
2 2
4 1
1 1 1 1
2

1
6 1
1 1 1 1 1 1
4
*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

6
5 3
1 2 2 3 3
2 3 4
4 2
1 2 2 4
2 4
5 2
2 3 3 4 4
5 5
6 1
1 1 1 1 1 1
4
4 2
1 1 1 2
2 2
4 1
1 1 1 1
2

output:

2
1 3 
-1
3
2 4 4 
5
1 1 1 2 3 
2
1 1 
-1

result:

ok ok (6 test cases)

Test #2:

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

input:

7056
4 3
1 1 1 1
1 1 1
4 3
1 1 1 1
1 1 2
4 3
1 1 1 1
1 1 3
4 3
1 1 1 1
1 1 4
4 3
1 1 1 1
1 1 5
4 3
1 1 1 1
1 1 6
4 3
1 1 1 1
1 2 2
4 3
1 1 1 1
1 2 3
4 3
1 1 1 1
1 2 4
4 3
1 1 1 1
1 2 5
4 3
1 1 1 1
1 2 6
4 3
1 1 1 1
1 3 3
4 3
1 1 1 1
1 3 4
4 3
1 1 1 1
1 3 5
4 3
1 1 1 1
1 3 6
4 3
1 1 1 1
1 4 4
4 3
1 1...

output:

-1
1
1 
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
1
2 
-1
-1
-1
1
1 
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
...

result:

ok ok (7056 test cases)

Test #3:

score: 0
Accepted
time: 0ms
memory: 5732kb

input:

5880
4 2
1 1 1 1
1 1
4 2
1 1 1 1
1 2
4 2
1 1 1 1
1 3
4 2
1 1 1 1
1 4
4 2
1 1 1 1
1 5
4 2
1 1 1 1
1 6
4 2
1 1 1 1
1 7
4 2
1 1 1 1
2 2
4 2
1 1 1 1
2 3
4 2
1 1 1 1
2 4
4 2
1 1 1 1
2 5
4 2
1 1 1 1
2 6
4 2
1 1 1 1
2 7
4 2
1 1 1 1
3 3
4 2
1 1 1 1
3 4
4 2
1 1 1 1
3 5
4 2
1 1 1 1
3 6
4 2
1 1 1 1
3 7
4 2
1 1...

output:

-1
-1
2
1 2 
-1
-1
-1
-1
2
1 1 
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
2
2 3 
-1
-1
-1
2
1 1 
2
2 1 
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
2
3 4 
-1
-1
-1
2
1 1 
2
3 1 
-1
-1
-1
2
1 2 
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
...

result:

ok ok (5880 test cases)

Test #4:

score: -100
Wrong Answer
time: 0ms
memory: 3644kb

input:

2640
4 1
1 1 1 1
1
4 1
1 1 1 1
2
4 1
1 1 1 1
3
4 1
1 1 1 1
4
4 1
1 1 1 1
5
4 1
1 1 1 1
6
4 1
1 1 1 1
7
4 1
1 1 1 1
8
4 1
1 1 1 2
1
4 1
1 1 1 2
2
4 1
1 1 1 2
3
4 1
1 1 1 2
4
4 1
1 1 1 2
5
4 1
1 1 1 2
6
4 1
1 1 1 2
7
4 1
1 1 1 2
8
4 1
1 1 1 3
1
4 1
1 1 1 3
2
4 1
1 1 1 3
3
4 1
1 1 1 3
4
4 1
1 1 1 3
5
4...

output:

-1
-1
3
1 1 2 
3
1 2 3 
-1
-1
-1
-1
-1
-1
3
1 1 2 
3
1 2 3 
3
2 3 4 
-1
-1
-1
-1
-1
3
1 1 2 
3
1 1 3 
3
1 3 4 
3
3 4 5 
-1
-1
-1
-1
-1
3
1 1 2 
3
1 1 4 
3
1 4 5 
3
4 5 6 
-1
-1
-1
-1
-1
3
1 1 2 
3
1 1 5 
3
1 5 6 
3
5 6 7 
-1
-1
-1
-1
-1
3
1 1 2 
3
1 1 6 
3
1 6 7 
-1
-1
-1
-1
-1
-1
3
1 1 2 
3
1 1 7 
...

result:

wrong answer Jury has answer but participant has not (test case 67)