Submission details
Task:Monikulmio
Sender:nikke5
Submission time:2025-11-05 17:38:07 +0200
Language:C++ (C++11)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED100
Test results
testverdicttimescore
#1ACCEPTED0.00 s10details
#2ACCEPTED0.00 s10details
#3ACCEPTED0.00 s10details
#4ACCEPTED0.00 s10details
#5ACCEPTED0.00 s10details
#6ACCEPTED0.00 s10details
#7ACCEPTED0.01 s10details
#8ACCEPTED0.01 s10details
#9ACCEPTED0.01 s10details
#10ACCEPTED0.04 s10details

Compiler report

input/code.cpp: In function 'int main()':
input/code.cpp:186:14: warning: unused variable 'sisalla' [-Wunused-variable]
  186 |         bool sisalla = false;
      |              ^~~~~~~

Code

#include <iostream>
#include <cmath>
#include <vector>
#include <algorithm>
#include <string>
#include <sstream>
#include <chrono>
#include <iomanip>

typedef long long ll;
using namespace std;

int main()
{

    ios_base::sync_with_stdio(0);
    cin.tie(0);

    int korkeus;
    int leveys;
    int kulmat;

    cin >> korkeus;
    cin >> leveys;
    cin >> kulmat;

    vector<pair<int, int>> kulmalista;

    vector<vector<string>> kuvio(korkeus, vector<string>(leveys, "."));

    for (int i = 0; i < kulmat; i++)
    {
        int x;
        int y;
        cin >> y;
        cin >> x;

        y--;
        x--;

        kulmalista.push_back({x, y});

        kuvio[y][x] = "*";
        // cout << kulmalista[i].first << " + " << kulmalista[i].second << "\n";

        if (i == 0)
        {
        }
        else
        {
            // aiempi piste samalla rivillä
            if (kulmalista[i - 1].second == y)
            {
                for (int c = 1; c < (abs(x - kulmalista[i - 1].first)); c++)
                {
                    int kohta = kulmalista[i - 1].first + c * ((x - kulmalista[i - 1].first) / (abs(x - kulmalista[i - 1].first)));
                    kuvio[y][kohta] = "=";
                }
            }

            // aiempi piste samalla sarakkeella
            else if (kulmalista[i - 1].first == x)
            {
                for (int c = 1; c < (abs(y - kulmalista[i - 1].second)); c++)
                {
                    int kohta = kulmalista[i - 1].second + c * ((y - kulmalista[i - 1].second) / (abs(y - kulmalista[i - 1].second)));
                    kuvio[kohta][x] = "|";
                }
            }

            // aiempi piste vinossa vasemmalle
            else if (kulmalista[i - 1].first - x < 0)
            {

                // vinossa alas:
                if (kulmalista[i - 1].second - y > 0)
                    for (int c = 1; c < (abs(y - kulmalista[i - 1].second)); c++)
                    {
                        int kohtay = kulmalista[i - 1].second + c * ((y - kulmalista[i - 1].second) / (abs(y - kulmalista[i - 1].second)));
                        int kohtax = kulmalista[i - 1].first + c * ((x - kulmalista[i - 1].first) / (abs(x - kulmalista[i - 1].first)));
                        kuvio[kohtay][kohtax] = "/";
                    }
                // vinossa ylös:
                if (kulmalista[i - 1].second - y < 0)
                    for (int c = 1; c < (abs(y - kulmalista[i - 1].second)); c++)
                    {
                        int kohtay = kulmalista[i - 1].second + c * ((y - kulmalista[i - 1].second) / (abs(y - kulmalista[i - 1].second)));
                        int kohtax = kulmalista[i - 1].first + c * ((x - kulmalista[i - 1].first) / (abs(x - kulmalista[i - 1].first)));
                        kuvio[kohtay][kohtax] = "\\";
                    }
            }
            // aiempi piste vinossa oikealle
            else if (kulmalista[i - 1].first - x > 0)
            {

                // vinossa alas:
                if (kulmalista[i - 1].second - y > 0)
                    for (int c = 1; c < (abs(y - kulmalista[i - 1].second)); c++)
                    {
                        int kohtay = kulmalista[i - 1].second + c * ((y - kulmalista[i - 1].second) / (abs(y - kulmalista[i - 1].second)));
                        int kohtax = kulmalista[i - 1].first + c * ((x - kulmalista[i - 1].first) / (abs(x - kulmalista[i - 1].first)));
                        kuvio[kohtay][kohtax] = "\\";
                    }
                // vinossa ylös:
                if (kulmalista[i - 1].second - y < 0)
                    for (int c = 1; c < (abs(y - kulmalista[i - 1].second)); c++)
                    {
                        int kohtay = kulmalista[i - 1].second + c * ((y - kulmalista[i - 1].second) / (abs(y - kulmalista[i - 1].second)));
                        int kohtax = kulmalista[i - 1].first + c * ((x - kulmalista[i - 1].first) / (abs(x - kulmalista[i - 1].first)));
                        kuvio[kohtay][kohtax] = "/";
                    }
            }
        }
    }

    // viimeistelyviiva:
    int i = kulmat;
    // aiempi piste samalla rivillä
    if (kulmalista[i - 1].second == kulmalista[0].second)
    {
        for (int c = 1; c < (abs(kulmalista[0].first - kulmalista[i - 1].first)); c++)
        {
            int kohta = kulmalista[i - 1].first + c * ((kulmalista[0].first - kulmalista[i - 1].first) / (abs(kulmalista[0].first - kulmalista[i - 1].first)));
            kuvio[kulmalista[0].second][kohta] = "=";
        }
    }

    // aiempi piste samalla sarakkeella
    if (kulmalista[i - 1].first == kulmalista[0].first)
    {
        for (int c = 1; c < (abs(kulmalista[0].second - kulmalista[i - 1].second)); c++)
        {
            int kohta = kulmalista[i - 1].second + c * ((kulmalista[0].second - kulmalista[i - 1].second) / (abs(kulmalista[0].second - kulmalista[i - 1].second)));
            kuvio[kohta][kulmalista[0].first] = "|";
        }
    }

    // aiempi piste vinossa vasemmalle
    else if (kulmalista[i - 1].first - kulmalista[0].first < 0)
    {

        // vinossa alas:
        if (kulmalista[i - 1].second - kulmalista[0].second > 0)
            for (int c = 1; c < (abs(kulmalista[0].second - kulmalista[i - 1].second)); c++)
            {
                int kohtay = kulmalista[i - 1].second + c * ((kulmalista[0].second - kulmalista[i - 1].second) / (abs(kulmalista[0].second - kulmalista[i - 1].second)));
                int kohtax = kulmalista[i - 1].first + c * ((kulmalista[0].first - kulmalista[i - 1].first) / (abs(kulmalista[0].first - kulmalista[i - 1].first)));
                kuvio[kohtay][kohtax] = "/";
            }
        // vinossa ylös:
        if (kulmalista[i - 1].second - kulmalista[0].second < 0)
            for (int c = 1; c < (abs(kulmalista[0].second - kulmalista[i - 1].second)); c++)
            {
                int kohtay = kulmalista[i - 1].second + c * ((kulmalista[0].second - kulmalista[i - 1].second) / (abs(kulmalista[0].second - kulmalista[i - 1].second)));
                int kohtax = kulmalista[i - 1].first + c * ((kulmalista[0].first - kulmalista[i - 1].first) / (abs(kulmalista[0].first - kulmalista[i - 1].first)));
                kuvio[kohtay][kohtax] = "\\";
            }
    }
    // aiempi piste vinossa oikealle
    else if (kulmalista[i - 1].first - kulmalista[0].first > 0)
    {

        // vinossa alas:
        if (kulmalista[i - 1].second - kulmalista[0].second > 0)
            for (int c = 1; c < (abs(kulmalista[0].second - kulmalista[i - 1].second)); c++)
            {
                int kohtay = kulmalista[i - 1].second + c * ((kulmalista[0].second - kulmalista[i - 1].second) / (abs(kulmalista[0].second - kulmalista[i - 1].second)));
                int kohtax = kulmalista[i - 1].first + c * ((kulmalista[0].first - kulmalista[i - 1].first) / (abs(kulmalista[0].first - kulmalista[i - 1].first)));
                kuvio[kohtay][kohtax] = "\\";
            }
        // vinossa ylös:
        if (kulmalista[i - 1].second - kulmalista[0].second < 0)
            for (int c = 1; c < (abs(kulmalista[0].second - kulmalista[i - 1].second)); c++)
            {
                int kohtay = kulmalista[i - 1].second + c * ((kulmalista[0].second - kulmalista[i - 1].second) / (abs(kulmalista[0].second - kulmalista[i - 1].second)));
                int kohtax = kulmalista[i - 1].first + c * ((kulmalista[0].first - kulmalista[i - 1].first) / (abs(kulmalista[0].first - kulmalista[i - 1].first)));
                kuvio[kohtay][kohtax] = "/";
            }
    }

    // täytä sisäpuoli:

    // käydään jokainen piste läpi:
    for (int y = 0; y < korkeus; y++)
    {
        bool sisalla = false;
        for (int x = 0; x < leveys; x++)
        {

            // käydään läpi ja aina kun tulee seinä vastaan aletaan täyttämään ja kun tulee seinä uudestaan lopetetaan:

/*             string merkki = kuvio[y][x];
            if (merkki == "/" || merkki == "\\" || merkki == "|")
            {
                sisalla = !sisalla;
            }
 */
/*             if (merkki == "*")
            {
                // cout << y << ": " << kuvio[y+1][x] << kuvio[y+1][x-1] << kuvio[y+1][x+1] << "\n";
                if (!((kuvio[y + 1][x] == "|" && kuvio[y + 1][x - 1] == "/") || (kuvio[y + 1][x] == "|" && kuvio[y + 1][x + 1] == "\\") || (kuvio[y + 1][x - 1] == "/" && kuvio[y + 1][x + 1] == "\\")))
                { // eli jos ei ole yläkärkipiste, eteenpäin
                    if (!((kuvio[y - 1][x] == "|" && kuvio[y - 1][x - 1] == "\\") || (kuvio[y - 1][x] == "|" && kuvio[y - 1][x + 1] == "/") || (kuvio[y - 1][x - 1] == "\\" && kuvio[y - 1][x + 1] == "/")))
                    { // eli jos ei ole alakärkipiste myöskään, muuta
                        sisalla = !sisalla;
                    }
                }
            } */

/*             if (merkki == "." && sisalla)
            {
                kuvio[y][x] = "#";
            } */

                        // jos on tyhjä kohta (ei kuviota)
                        if (kuvio[y][x] == ".")
                        {

                            // selvitä onko kuvion sisäpuolella:
                            // looppaa kaikki sivut:

                            int leikkaukset = 0; // raycastin leikkaukset sivun kanssa

                            for (int i = 0; i < kulmat; i++)
                            {
                                pair<int, int> kulma1 = kulmalista[i];
                                pair<int, int> kulma2 = kulmalista[(i + 1) % kulmat];

                                if (y > min(kulma1.second, kulma2.second) // piste on jommankumman sivun pisteen yläpuolella
                                    && y <= max(kulma1.second, kulma2.second) // piste on jommankumman sivun pisteen alapuolella (yht nämä kaks = piste on jossain sivun kohdalla)
                                                && x <= max(kulma2.first, kulma1.first)) //piste on sivun jommankumman pisteen vasemmalla puolella
                                {
                                    // lasketaan kohta jossa pisteestä x,y tehty linja oikealle päin osuu sivuun:
                                    double xLeikkaus = (y - kulma1.second) * (kulma2.first - kulma1.first) / (kulma2.second - kulma1.second) + kulma1.first;

                                    if (x <= xLeikkaus){
                                        leikkaukset++;
                                    }
                                }
                            }

                            if (leikkaukset % 2 == 1)
                            { // jos leikkausten määrä pariton, piste sisällä
                                kuvio[y][x] = "#";
                            }
                        }
        }
    }

    for (int y = 0; y < korkeus; y++)
    {
        for (int x = 0; x < leveys; x++)
        {
            cout << kuvio[y][x];
        }
        cout << "\n";
    }

    // cout << korkeus << " + " << leveys << " + " << kulmat << "\n";
}

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
*=====*===*==*...................

Test 10 (public)

Verdict: ACCEPTED

input
100 100 1000
10 1
4 7
1 4
1 9
...

correct output
...*====*........................

user output
...*====*........................