| Task: | Monikulmio |
| Sender: | Sukarth |
| Submission time: | 2025-10-27 08:03:10 +0200 |
| Language: | C++ (C++20) |
| Status: | READY |
| Result: | 94 |
| group | verdict | score |
|---|---|---|
| #1 | ACCEPTED | 94 |
| test | verdict | time | score | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | 10 | details |
| #2 | ACCEPTED | 0.00 s | 10 | details |
| #3 | ACCEPTED | 0.00 s | 10 | details |
| #4 | ACCEPTED | 0.00 s | 10 | details |
| #5 | ACCEPTED | 0.00 s | 10 | details |
| #6 | ACCEPTED | 0.00 s | 10 | details |
| #7 | ACCEPTED | 0.00 s | 10 | details |
| #8 | ACCEPTED | 0.00 s | 10 | details |
| #9 | ACCEPTED | 0.00 s | 7 | details |
| #10 | ACCEPTED | 0.00 s | 7 | details |
Compiler report
input/code.cpp: In function 'int main()':
input/code.cpp:91:18: warning: unused variable 'b' [-Wunused-variable]
91 | char b;
| ^Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n, m, k;
vector<vector<char>> grid(101, vector<char>(101, '.'));
vector<vector<bool>> visited(101, vector<bool>(101, false));
void dfs(ll i, ll j) {
if (visited[i][j]) return;
visited[i][j] = true;
int dx[] = {-1, 1, 0, 0};
int dy[] = {0, 0, -1, 1};
grid[i][j] = 'O';
for (int dir = 0; dir < 4; dir++) {
int ni = i + dx[dir];
int nj = j + dy[dir];
if (ni >= 0 && ni < n + 2 && nj >= 0 && nj < m + 2 && !visited[ni][nj] && grid[ni][nj] == '.') {
dfs(ni, nj);
}
}
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n >> m >> k;
grid.assign(n + 2, vector<char>(m + 2, '.'));
visited.assign(n + 2, vector<bool>(m + 2, false));
vector<pair<int, int>> corners(k);
for (ll i = 0; i < k; i++) {
cin >> corners[i].first >> corners[i].second;
grid[corners[i].first][corners[i].second] = '*';
}
for (ll i = 0; i < k; i++) {
ll y1 = corners[i].first;
ll x1 = corners[i].second;
ll y2 = corners[(i+1) % k].first;
ll x2 = corners[(i+1) % k].second;
if (x2 == x1) {
for (ll i = min(y1, y2)+1; i < max(y1, y2); i++) {
grid[i][x2] = '|';
}
}
else if (y2 == y1) {
for (ll j = min(x1, x2)+1; j < max(x1, x2); j++) {
grid[y2][j] = '=';
}
}
else {
ll ystep = -1, xstep = -1;
if (y2 > y1) ystep = 1;
if (x2 > x1) xstep = 1;
char charr = '/';
if (ystep == xstep) charr = '\\';
ll cury = y1 + ystep;
ll curx = x1 + xstep;
while (cury != y2) {
grid[cury][curx] = charr;
cury += ystep;
curx += xstep;
}
}
}
dfs(0, 0);
for (ll i = 1; i <= n; i++) {
for (ll j = 1; j <= m; j++) {
char b;
if (grid[i][j] == '.') {
cout << '#';
}
else if (grid[i][j] == 'O') {
cout << '.';
} else {
cout << grid[i][j];
}
}
cout << "\n";
}
return 0;
}Test details
Test 1 (public)
Verdict: ACCEPTED
| input |
|---|
| 8 9 5 5 2 2 5 5 8 7 8 ... |
| correct output |
|---|
| ......... ....*.... .../#\... ../###\.. .*#####*. ... |
| user output |
|---|
| ......... ....*.... .../#\... ../###\.. .*#####*. ... |
Test 2 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 4 5 10 5 30 15 30 15 10 |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 3 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 29 8 7 13 2 14 2 9 7 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 4 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 14 5 12 5 25 8 28 13 28 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 5 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 12 3 20 7 16 7 9 11 13 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 6 (public)
Verdict: ACCEPTED
| input |
|---|
| 9 35 33 2 3 2 8 4 8 4 5 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 7 (public)
Verdict: ACCEPTED
| input |
|---|
| 30 100 69 6 10 6 14 7 14 7 18 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 8 (public)
Verdict: ACCEPTED
| input |
|---|
| 40 60 192 11 3 11 5 10 6 11 7 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Test 9 (public)
Verdict: ACCEPTED
| input |
|---|
| 50 100 142 1 1 1 7 1 11 1 14 ... |
| correct output |
|---|
| *=====*===*==*................... |
| user output |
|---|
| *=====*===*==*................... |
Feedback: Lines are drawn correctly. Incorrect fill character on row 3, col 9: expected '.', got '#'
Test 10 (public)
Verdict: ACCEPTED
| input |
|---|
| 100 100 1000 10 1 4 7 1 4 1 9 ... |
| correct output |
|---|
| ...*====*........................ |
| user output |
|---|
| ...*====*........................ |
Feedback: Lines are drawn correctly. Incorrect fill character on row 4, col 29: expected '.', got '#'
