COCI '17 Contest 4 #4 Vođe

View as PDF

Submit solution

Points: 12 (partial)
Time limit: 1.4s
Memory limit: 512M

Problem types

As we all very well know, goats and sheep have been fighting for years about the fields they're grazing. After many fierce fights, the goat leader and the sheep leader decided to meet to try to find a peaceful solution to their problem. After many hours of discussion, they agreed that they will play a game for each field and that the winner will get to graze that field.

The game is played such that a total of N animals (that can be goats or sheep) form a circle (the exact order of goats and sheep is an agreement between their leaders). After animal i (1 \le i \le N-1), the game is continued by animal i+1, and after animal N, the game is continued by animal 1. The animal starting the game can say any positive integer from the interval [1, K], but only if that number is not greater than M. If the animal that started the game said the number j, then the next animal can say a number in interval [j+1, j+K], but only if that number is not greater than M. In other words, each animal can say a number that is greater by minimally 1, and maximally by K than the number said by the animal before, but only if the new number is not greater than M. If an animal must say number M, its team (goats or sheep) loses.

If both the goats and the sheep are playing optimally, for each i (1 \le i \le N), determine who will win the field if the game is started by the i^{th} animal.

Input Specification

The first line of input contains N, M and K (1 \le N, M, K \le 5000), the numbers from the task.
The following line contains N numbers, 0 if the i^{th} animal is a sheep, and 1 if it's a goat.

Output Specification

Output N space-separated numbers. For each animal i (1 \le i \le N) output 0 if the sheep will win the field, and 1 if the goats will win, if the i^{th} animal is starting the game.

Scoring

In test cases worth a total of 60\% of points, it will hold 1 \le N, M, K \le 500.

Sample Input 1

2 9 2
0 1

Sample Output 1

0 1

Explanation for Sample Output 1

When a sheep is playing first, it can play like this: The sheep starts with number 2, after which the goat can say 3 or 4. In both cases, the sheep can say 5, after which the goat can say either 6 or 7. In both cases, the sheep can say 8, after which the goat doesn't have any other choice but 9 and thus losing the game and the field.

Sample Input 2

6 499 5
1 0 0 1 1 0

Sample Output 2

0 1 1 1 1 0

Sample Input 3

10 100 10
0 0 0 1 1 1 1 0 1 1

Sample Output 3

1 1 1 1 1 1 1 1 1 1

Comments

There are no comments at the moment.