![](/static/branding/mistrzostwa/2024/map_logo.jpg)
![](/static/branding/mistrzostwa/2024/mc_logo.png)
![](/static/branding/mistrzostwa/2024/uwr_logo.png)
![](/static/branding/mistrzostwa/2024/uw_logo.png)
![](/static/branding/mistrzostwa/2024/fii_logo.jpeg)
![](/static/branding/mistrzostwa/2024/fri_logo.png)
Mistrzostwa Polski Szkół Średnich w Programowaniu Zespołowym 2024
Problem description
Jasio, przygotowując się na przyjęcie gości, postanowił udekorować swój dom. Przeglądając internet, natrafił na fraktal o ciekawym wyglądzie – dywan Sierpińskiego. Wpadł na pomysł, aby wydrukować go na plakatach i przykleić do ścian. Niestety, jego stara drukarka obsługuje wyłącznie standardowe znaki ASCII.
Pomóż Jasiowi i napisz program, który wczyta stopień fraktalu i
wydrukuje go przy użyciu jedynie znaków spacji oraz #
.
Dywan stopnia 0 (D0) to pojedynczy znak
#
.
Dywan stopnia k + 1 (Dk + 1) otrzymujemy, układając osiem kopii dywanu stopnia Dk w układzie 3×3, pozostawiając środkowy fragment pusty.
Graficzna ilustracja tego procesu:
Puste miejsca w trakcie konstrukcji kolejnych stopni fraktalu należy wypełnić spacjami (patrz przykłady).
Wejście
W pierwszym (jedynym) wierszu wejścia znajduje się pojedyczna liczba całkowita n, oznaczająca poziom fraktalu, jaki należy wypisać.
Wyjście
Na wyjściu powinien znaleźć się dywan sierpińskiego według powyżej opisanych reguł i konwencji.
Ograniczenia
0 ≤ n ≤ 7.
Przykład
Wejście | Wyjście | Wyjaśnienie |
|
|
D0 reprezentujemy poprzez
pojedyczny znak |
Wejście | Wyjście | Wyjaśnienie |
|
|
Pojedyncze zagnieżdżenie procedury rysującej dywan da wskazany rezultat. |
Wejście | Wyjście | Wyjaśnienie |
|
|
Dwukrotne zagnieżdżenie procedury rysującej dywan da wskazany rezultat. |