COCI 2006/2007, Croatian Regional
Tetris is a popular computer game played in a field consisting of C columns and an unlimited number of rows. In one move, one of the following seven pieces is dropped into the field:
When dropping the piece, the player is free to rotate the piece 90, 180 or 270 degrees and to move it left or right, as long as the piece stays entirely in the field. The piece then falls until it settles on the bottom of the field or on already occupied squares. In our variant of Tetris the piece must fall so that all parts of the piece are on the bottom of the field or on already occupied squares. In other words, after the piece falls there may not be a free square such that some square above it is occupied.
For example, let the field be six columns wide with initial heights (the number of already occupied squares in each column) 2, 1, 1, 1, 0 and 1. Piece number 5 can then be dropped into the field in five different ways:
You are given the initial heights of all columns and the figure to be dropped into the field.
Write a program that calculates the number of different ways to do this, i.e. the number of different field configurations that can be achieved by dropping the piece.
The first line contains two integers C and P, 1 ≤ C ≤ 100, 1 ≤ P ≤ 7, the number of columns and the number of the piece to be dropped.
The second line contains C integers separated by single spaces, each between 0 and 100, inclusive. These are the initial heights of the columns.
Output on a single line the number of different ways to drop the piece in the field.
6 5 2 1 1 1 0 1
5 1 0 0 0 0 0
9 4 4 3 5 4 6 5 7 6 6
Point Value: 10
Time Limit: 1.00s
Memory Limit: 32M
Added: Jul 13, 2013
C++03, PAS, C, HASK, ASM, RUBY, PYTH2, JAVA, PHP, SCM, CAML, PERL, C#, C++11, PYTH3