CSES - Datatähti 2018 alku - Results
Submission details
Task:Fraktaali
Sender:inv41idu53rn4m3
Submission time:2017-10-04 15:04:39 +0300
Language:C++
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED10
#2ACCEPTED10
#3ACCEPTED10
#4ACCEPTED10
#5ACCEPTED10
#6ACCEPTED10
#7ACCEPTED10
#8ACCEPTED10
#9ACCEPTED10
#10ACCEPTED10
Test results
testverdicttimegroup
#1ACCEPTED0.06 s1details
#2ACCEPTED0.04 s2details
#3ACCEPTED0.05 s3details
#4ACCEPTED0.04 s4details
#5ACCEPTED0.07 s5details
#6ACCEPTED0.05 s6details
#7ACCEPTED0.05 s7details
#8ACCEPTED0.04 s8details
#9ACCEPTED0.05 s9details
#10ACCEPTED0.06 s10details

Code

#include <iostream>
#include <cstdlib>

using namespace std;

uint pow2(uint x) {
    if (x == 0) {
        return 1;
    } else {
        return 2 * pow2(x - 1);
    }
}

int main() {
    char input[8]; // Why am I even reserving 8 bytes for this?
    uint level; // Depth of the fractal

    cin >> input;
    level = atoi(input); // Dirty I know :P

    if (level > 1) {
        uint size = pow2(level - 1);
        bool* fractal = new bool [size * size];

        fractal[0] = true;

        for (uint i = 0; i < level - 1; i++) { // Stuff that I'm too lazy to explain
            uint isize = pow2(i);
            for (uint x = 0; x < isize; x++) {
                for (uint y = 0; y < isize; y++) {
                    fractal[(y + isize) * size + x + isize] = !fractal[y * size + x];
                    fractal[(y) * size + x + isize] = fractal[y * size + x];
                    fractal[(y + isize) * size + x] = fractal[y * size + x];
                }
            }
        }

        for (uint y = 0; y < size; y++) { // Convert fractal table to text
            for (uint x = 0; x < size; x++) {
                if (fractal[y * size + x]) {
                    cout << "#";
                } else {
                    cout << ".";
                }
            }
            cout << endl;
        }

        return 0;
    } else {
        cout << "#" << endl;
        return 0;
    }
}

Test details

Test 1

Group: 1

Verdict: ACCEPTED

input
1

correct output
#

user output
#

Test 2

Group: 2

Verdict: ACCEPTED

input
2

correct output
##
#.

user output
##
#.

Test 3

Group: 3

Verdict: ACCEPTED

input
3

correct output
####
#.#.
##..
#..#

user output
####
#.#.
##..
#..#

Test 4

Group: 4

Verdict: ACCEPTED

input
4

correct output
########
#.#.#.#.
##..##..
#..##..#
####....
...

user output
########
#.#.#.#.
##..##..
#..##..#
####....
...

Test 5

Group: 5

Verdict: ACCEPTED

input
5

correct output
################
#.#.#.#.#.#.#.#.
##..##..##..##..
#..##..##..##..#
####....####....
...

user output
################
#.#.#.#.#.#.#.#.
##..##..##..##..
#..##..##..##..#
####....####....
...

Test 6

Group: 6

Verdict: ACCEPTED

input
6

correct output
##############################...

user output
##############################...

Test 7

Group: 7

Verdict: ACCEPTED

input
7

correct output
##############################...

user output
##############################...

Test 8

Group: 8

Verdict: ACCEPTED

input
8

correct output
##############################...

user output
##############################...

Test 9

Group: 9

Verdict: ACCEPTED

input
9

correct output
##############################...

user output
##############################...

Test 10

Group: 10

Verdict: ACCEPTED

input
10

correct output
##############################...

user output
##############################...