QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#789433 | #6515. Path Planning | LianYan | WA | 14ms | 3696kb | C++20 | 1.7kb | 2024-11-27 20:20:33 | 2024-11-27 20:20:40 |
Judging History
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'