QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#789433#6515. Path PlanningLianYanWA 14ms3696kbC++201.7kb2024-11-27 20:20:332024-11-27 20:20:40

Judging History

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

  • [2024-11-27 20:20:40]
  • 评测
  • 测评结果:WA
  • 用时:14ms
  • 内存:3696kb
  • [2024-11-27 20:20:33]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
// #define int long long
#define endl '\n'

void solve()
{
    int n, m;
    cin >> n >> m;
    pair<int, int> pos[n * m];
    int a[n + 2][m + 2] = {0};
    int le[n + 1], ri[n + 1];
    for (int i = 1; i <= n; i++)
    {
        le[i] = -1;
        ri[i] = 0x3f3f3f;
        for (int j = 1; j <= m; j++)
        {
            cin >> a[i][j];
            pos[a[i][j]] = {i, j};
        }
    }
    int ans = 1;
    // le[pos[0].first] = pos[0].second;
    for (int _ = pos[0].first - 1; _ > 0; _--)
        if (ri[_] < pos[0].second)
            break;
        else
            ri[_] = pos[0].second;
    for (int _ = pos[0].first + 1; _ <= n; _++)
        if (le[_] > pos[0].second)
            break;
        else
            le[_] = pos[0].second;
    for (int i = 1; i < n * m; i++)
    {
        int x, y;
        x = pos[i].first;
        y = pos[i].second;

        if (le[x] == -1)
        {
            if (y > ri[x])
                break;
        }
        else if (ri[x] == 0x3f3f3f)
        {
            if (y < le[x])
                break;
        }
        else
        {
            if (y < le[x] || y > ri[x])
                break;
        }
        for (int _ = x - 1; _ > 0; _--)
            if (ri[_] < y)
                break;
            else
                ri[_] = y;
        for (int _ = x + 1; _ <= n; _++)
            if (le[_] > y)
                break;
            else
                le[_] = y;
        ans = i;
    }
    cout << ++ans << endl;
}

signed main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    int T;
    cin >> T;
    while (T--)
        solve();
    return 0;
}

详细

Test #1:

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

input:

2
2 3
1 2 4
3 0 5
1 5
1 3 0 4 2

output:

3
5

result:

ok 2 number(s): "3 5"

Test #2:

score: -100
Wrong Answer
time: 14ms
memory: 3692kb

input:

10000
2 9
4 0 3 5 2 7 16 11 12
9 13 14 17 10 8 15 1 6
4 8
19 23 22 13 29 4 17 26
30 6 25 3 15 24 18 14
12 8 7 9 27 5 0 10
11 16 31 20 2 28 1 21
1 6
3 2 0 1 4 5
2 3
4 2 0
3 5 1
5 1
4
0
3
2
1
1 3
1 0 2
8 10
9 50 8 0 41 57 60 30 23 65
64 21 36 12 10 5 58 19 38 67
71 52 45 17 77 4 59 51 22 25
56 49 79 2...

output:

9
2
6
3
5
3
14
13
5
9
5
7
6
9
7
4
6
7
13
9
10
9
6
2
5
7
4
2
10
4
18
5
12
3
7
6
9
2
2
5
6
10
8
4
2
5
2
5
7
13
6
10
2
10
3
6
9
8
3
10
2
3
3
5
8
4
7
7
7
8
8
6
6
5
3
7
7
13
3
3
6
5
4
3
10
5
12
7
2
11
6
7
5
10
9
5
3
10
2
5
3
8
7
10
5
4
10
4
6
5
9
4
10
6
3
5
4
4
7
4
8
3
12
5
4
5
8
6
8
3
7
9
3
6
12
4
6
6
6...

result:

wrong answer 24th numbers differ - expected: '1', found: '2'