| Task: | Ruudukko |
| Sender: | motsgar |
| Submission time: | 2021-12-09 14:40:01 +0200 |
| Language: | C++ (C++17) |
| Status: | READY |
| Result: | 100 |
| group | verdict | score |
|---|---|---|
| #1 | ACCEPTED | 17 |
| #2 | ACCEPTED | 42 |
| #3 | ACCEPTED | 41 |
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.01 s | 1 | details |
| #2 | ACCEPTED | 0.01 s | 1 | details |
| #3 | ACCEPTED | 0.01 s | 1 | details |
| #4 | ACCEPTED | 0.01 s | 1 | details |
| #5 | ACCEPTED | 0.01 s | 1 | details |
| #6 | ACCEPTED | 0.01 s | 2 | details |
| #7 | ACCEPTED | 0.01 s | 2 | details |
| #8 | ACCEPTED | 0.01 s | 2 | details |
| #9 | ACCEPTED | 0.01 s | 2 | details |
| #10 | ACCEPTED | 0.01 s | 2 | details |
| #11 | ACCEPTED | 0.02 s | 3 | details |
| #12 | ACCEPTED | 0.01 s | 3 | details |
| #13 | ACCEPTED | 0.01 s | 3 | details |
| #14 | ACCEPTED | 0.01 s | 3 | details |
| #15 | ACCEPTED | 0.01 s | 3 | details |
Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(int argc, char **argv)
{
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int n;
cin >> n;
vector<vector<char>> v(n);
vector<vector<bool>> u(n);
for (int i = 0; i < n; i++)
{
v[i].resize(n);
u[i].resize(n);
for (int j = 0; j < n; j++)
{
u[i][j] = false;
cin >> v[i][j];
}
}
vector<pair<int,int>> p;
p.push_back(make_pair(0, 0));
cout << v[0][0];
for (int i = 0; i < 2*n - 1; i++)
{
vector<pair<int,int>> pc;
char smallest = 'Z';
for (auto pa : p)
{
if (pa.second + 1 >= n || pa.first + 1 >= n)
{
bool w;
if (pa.second + 1 >= n) w = false;
else w = true;
if (w == false && pa.first + 1 >= n)
{
goto exit;
}
if (w)
{
if (u[pa.first][pa.second + 1]) continue;
char b = v[pa.first][pa.second + 1];
if (b < smallest) pc.clear();
if (b <= smallest)
pc.push_back(make_pair(pa.first, pa.second + 1));
u[pa.first][pa.second + 1] = true;
if (b < smallest) smallest = b;
}
else
{
if (u[pa.first + 1][pa.second]) continue;
char a = v[pa.first + 1][pa.second];
if (a < smallest) pc.clear();
if (a <= smallest)
pc.push_back(make_pair(pa.first + 1, pa.second));
u[pa.first + 1][pa.second] = true;
if (a < smallest) smallest = a;
}
continue;
}
if (pa.second + 1 >= n || v[pa.first + 1][pa.second] < v[pa.first][pa.second + 1])
{
if (u[pa.first + 1][pa.second]) continue;
char a = v[pa.first + 1][pa.second];
if (a < smallest) pc.clear();
if (a <= smallest)
pc.push_back(make_pair(pa.first + 1, pa.second));
u[pa.first + 1][pa.second] = true;
if (a < smallest) smallest = a;
}
else if (pa.first + 1 >= n || v[pa.first][pa.second + 1] < v[pa.first + 1][pa.second])
{
if (u[pa.first][pa.second + 1]) continue;
char b = v[pa.first][pa.second + 1];
if (b < smallest) pc.clear();
if (b <= smallest)
pc.push_back(make_pair(pa.first, pa.second + 1));
u[pa.first][pa.second + 1] = true;
if (b < smallest) smallest = b;
}
else
{
char b = v[pa.first][pa.second + 1];
if (b < smallest) pc.clear();
if (b <= smallest)
{
if (!u[pa.first][pa.second + 1])
pc.push_back(make_pair(pa.first, pa.second + 1));
if (!u[pa.first + 1][pa.second])
pc.push_back(make_pair(pa.first + 1, pa.second));
u[pa.first][pa.second + 1] = true;
u[pa.first + 1][pa.second] = true;
}
if (b < smallest) smallest = b;
}
}
p = pc;
cout << smallest;
}
exit:
cout << '\n';
}
Test details
Test 1
Group: 1
Verdict: ACCEPTED
| input |
|---|
| 5 AAAAA AAAAA AAAAA AAAAA ... |
| correct output |
|---|
| AAAAAAAAB |
| user output |
|---|
| AAAAAAAAB |
Test 2
Group: 1
Verdict: ACCEPTED
| input |
|---|
| 5 ABABA BABAB ABABA BABAB ... |
| correct output |
|---|
| ABABABABA |
| user output |
|---|
| ABABABABA |
Test 3
Group: 1
Verdict: ACCEPTED
| input |
|---|
| 5 WRYIU TWLKH UJMJC GRDJW ... |
| correct output |
|---|
| WRWJMDJWK |
| user output |
|---|
| WRWJMDJWK |
Test 4
Group: 1
Verdict: ACCEPTED
| input |
|---|
| 5 RUEAE ZYHHW KDBPD DXREW ... |
| correct output |
|---|
| RUEAEWDWX |
| user output |
|---|
| RUEAEWDWX |
Test 5
Group: 1
Verdict: ACCEPTED
| input |
|---|
| 5 SRGYR MYDOB GNOVM SZOZK ... |
| correct output |
|---|
| SMGNOOLTU |
| user output |
|---|
| SMGNOOLTU |
Test 6
Group: 2
Verdict: ACCEPTED
| input |
|---|
| 100 AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... |
| correct output |
|---|
| AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... |
| user output |
|---|
| AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... Truncated |
Test 7
Group: 2
Verdict: ACCEPTED
| input |
|---|
| 100 ABABABABABABABABABABABABABABAB... |
| correct output |
|---|
| ABABABABABABABABABABABABABABAB... |
| user output |
|---|
| ABABABABABABABABABABABABABABAB... Truncated |
Test 8
Group: 2
Verdict: ACCEPTED
| input |
|---|
| 100 FWOVNYKNMMQCNHJGUYPNEDXGVVGONC... |
| correct output |
|---|
| FWDBDECKBHKIACOVUCJGDJOHAYIBHO... |
| user output |
|---|
| FWDBDECKBHKIACOVUCJGDJOHAYIBHO... Truncated |
Test 9
Group: 2
Verdict: ACCEPTED
| input |
|---|
| 100 ETGCJABWKMAAEOQXWFFYMDJBMNKMQK... |
| correct output |
|---|
| EAARGLBRLHCDHHBPABHDAJBEEBHQBE... |
| user output |
|---|
| EAARGLBRLHCDHHBPABHDAJBEEBHQBE... Truncated |
Test 10
Group: 2
Verdict: ACCEPTED
| input |
|---|
| 100 GNWMLJNHSBAADUFCSGIZMWHZTVDHNR... |
| correct output |
|---|
| GEGOFRDKBNLLEUOPOEQCEFMTKANLNC... |
| user output |
|---|
| GEGOFRDKBNLLEUOPOEQCEFMTKANLNC... Truncated |
Test 11
Group: 3
Verdict: ACCEPTED
| input |
|---|
| 500 AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... |
| correct output |
|---|
| AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... |
| user output |
|---|
| AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA... Truncated |
Test 12
Group: 3
Verdict: ACCEPTED
| input |
|---|
| 500 ABABABABABABABABABABABABABABAB... |
| correct output |
|---|
| ABABABABABABABABABABABABABABAB... |
| user output |
|---|
| ABABABABABABABABABABABABABABAB... Truncated |
Test 13
Group: 3
Verdict: ACCEPTED
| input |
|---|
| 500 HGADXTSFXYIEMDWMFIVQGHTACFUPYI... |
| correct output |
|---|
| HGADEJOGAKPJCRAHTABRSDLAVGBFAG... |
| user output |
|---|
| HGADEJOGAKPJCRAHTABRSDLAVGBFAG... Truncated |
Test 14
Group: 3
Verdict: ACCEPTED
| input |
|---|
| 500 SBLNMAZESQVGWAPZYHQJMQTNGMEZWS... |
| correct output |
|---|
| SBLCAMDHILGIDRCIDUNMMAHFYCENOS... |
| user output |
|---|
| SBLCAMDHILGIDRCIDUNMMAHFYCENOS... Truncated |
Test 15
Group: 3
Verdict: ACCEPTED
| input |
|---|
| 500 AOXYXRYFWPYWQDPWXQITLHQQUAYZAJ... |
| correct output |
|---|
| AOJLDOAPBGEKSGCNKBUMKAJCCWCOOD... |
| user output |
|---|
| AOJLDOAPBGEKSGCNKBUMKAJCCWCOOD... Truncated |
