| Task: | Monikulmio |
| Sender: | AapoApina |
| Submission time: | 2025-10-28 09:48:43 +0200 |
| Language: | C++ (C++20) |
| Status: | READY |
| Result: | 70 |
| group | verdict | score |
|---|---|---|
| #1 | ACCEPTED | 70 |
| test | verdict | time | score | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | 7 | details |
| #2 | ACCEPTED | 0.00 s | 7 | details |
| #3 | ACCEPTED | 0.00 s | 7 | details |
| #4 | ACCEPTED | 0.00 s | 7 | details |
| #5 | ACCEPTED | 0.00 s | 7 | details |
| #6 | ACCEPTED | 0.00 s | 7 | details |
| #7 | ACCEPTED | 0.00 s | 7 | details |
| #8 | ACCEPTED | 0.00 s | 7 | 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:93:17: warning: unused variable 'endY' [-Wunused-variable]
93 | int endY=max(y,firstY);
| ^~~~Code
#include<bits/stdc++.h>
using namespace std;
int main(void){
int n,m,k; //n = korkeus; m = leveys; k = kärkien lukumäärä
cin >> n >> m >> k;
vector<vector<char>> arr(n,vector<char>(m,'.'));
int x,y,firstX,firstY,prevX,prevY;
cin >> firstY >> firstX;
arr[firstY-1][firstX-1]='*';
prevX=firstX;
prevY=firstY;
//iterate over the points
for(int i=0; i<k-1;i++){
cin >> y >> x;
arr[y-1][x-1]='*';
//point straight to the side
if(prevY==y){
int start = min(x,prevX);
int end = max(x,prevX)-1;
for(int j=start;j<end;j++){
arr[y-1][j] = '=';
}
}
//point straight down
else if(prevX==x){
int start = min(y,prevY);
int end = max(y,prevY)-1;
for(int j=start;j<end;j++){
arr[j][x-1] = '|';
}
}
//rising diagonal
else if ((prevY > y && prevX < x) || (y > prevY && x < prevX)) {
int startX = min(x, prevX);
int endX = max(x, prevX);
int startY = max(y, prevY) - 1;
for (int j = 1; j < endX - startX; j++) {
arr[startY - j ][startX + j - 1] = '/';
}
}
//falling diagonal
else {
int startX = min(x, prevX);
int endX = max(x, prevX);
int startY = min(y, prevY);
for (int j = 1; j < endX - startX; j++) {
arr[startY + j - 1][startX + j - 1] = '\\';
}
}
//set previous x and y
prevX = x;
prevY = y;
}
//connect first and last point
//point straight to the side
if(firstY==y){
int start = min(x,firstX);
int end = max(x,firstX)-1;
for(int j=start;j<end;j++){
arr[y-1][j] = '=';
}
}
//point straight down //**CHECK IF WORKS STRAIGHT UP**
else if(firstX==x){
int start = min(y,firstY);
int end = max(y,firstY)-1;
for(int j=start;j<end;j++){
arr[j][x-1] = '|';
}
}
//rising diagonal
else if((firstY > y && firstX < x) || (y > firstY && x < firstX)){
int startX = min(x, firstX);
int startY = max(y, firstY) - 1;
int endX = max(x, firstX);
for (int j = 1; j < endX - startX; j++) {
arr[startY - j ][startX + j - 1] = '/';
}
}
else {
int startX=min(x,firstX);
int startY=min(y,firstY);
int endX=max(x,firstX)-1;
int endY=max(y,firstY);
for(int j=0; j<endX-startX;j++){
arr[startY+j][startX+j]='\\';
}
}
//fill the array
//print the array
for(int i=0; i<n;i++){
for(int j=0;j<m;j++){
cout << arr[i][j];
}
cout << '\n';
}
}Test details
Test 1 (public)
Verdict: ACCEPTED
| input |
|---|
| 8 9 5 5 2 2 5 5 8 7 8 ... |
| correct output |
|---|
| ......... ....*.... .../#\... ../###\.. .*#####*. ... |
| user output |
|---|
| ......... ....*.... .../.\... ../...\.. .*.....*. ... |
Feedback: Lines are drawn correctly. Incorrect fill character on row 3, col 5: expected '#', got '.'
Test 2 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 4 5 10 5 30 15 30 15 10 |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 6, col 11: expected '#', got '.'
Test 3 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 29 8 7 13 2 14 2 9 7 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 4, col 30: expected '#', got '.'
Test 4 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 14 5 12 5 25 8 28 13 28 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 4, col 10: expected '#', got '.'
Test 5 (public)
Verdict: ACCEPTED
| input |
|---|
| 20 40 12 3 20 7 16 7 9 11 13 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 4, col 20: expected '#', got '.'
Test 6 (public)
Verdict: ACCEPTED
| input |
|---|
| 9 35 33 2 3 2 8 4 8 4 5 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 3, col 3: expected '#', got '.'
Test 7 (public)
Verdict: ACCEPTED
| input |
|---|
| 30 100 69 6 10 6 14 7 14 7 18 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 7, col 10: expected '#', got '.'
Test 8 (public)
Verdict: ACCEPTED
| input |
|---|
| 40 60 192 11 3 11 5 10 6 11 7 ... |
| correct output |
|---|
| ................................. |
| user output |
|---|
| ................................. |
Feedback: Lines are drawn correctly. Incorrect fill character on row 3, col 30: expected '#', got '.'
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 2, col 11: 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 2, col 6: expected '#', got '.'
