TopCoder problem "CircuitConstruction" used in MM 34 (Division I Level One)



Problem Statement

    The board consists of WxH squares. Each square has several lines of wire on it, each line connecting the center of the square with the middle of one of the sides of the square.

Left and right sides of the board have H contacts each, positioned at the middles of squares' sides. Each contact can be either active or not, and it will stay in the same state throughout the simulation.

Your goal is to connect some active contacts at the left and right sides using the wire on the squares (see "Scoring" for clarification). To get the desired wire configuration, you can rotate squares 90 degrees clockwise or counterclockwise, one rotation of one square per step.

Implementation

Your code should implement two methods, as described below:
  • init (int W, int H, String C). This method is called once per test case, giving you width of the board W, height of the board H and a list of activity states of contacts C. Elements 0..H-1 of C describe contacts 0..H-1 on the left side, and elements H..2*H-1 describe contacts 0..H-1 on the right side (contacts on each side are numbered top-down). Each element of C will be '1' for active contact or '0' for inactive one.
  • rotateSquare (int[] board). This method is called once per step, to define the square you want to rotate. board describes the current state of the board, square at row i and column j being described with board[i*W+j] (row 0 is the topmost, column 0 is the leftmost). The wires' placement on the square is encoded as an integer using one bit per square's side, ordered top-right-bottom-left starting with the lowest bit, bit value of 1 meaning that there is a wire between the center of the square and the middle of this side.

    You can decode the values as top=sq&1, right=(sq>>1)&1, bottom=(sq>>2)&1, left=(sq>>3)&1.

    You must return a int[] with three elements, i, j and s, indicating the row index and the column index of the square to be rotated and its sign of rotation (1 for clockwise and -1 for counterclockwise).

Scoring

After each call of rotateSquare it is checked whether there exists an active contact on the left connected with an active contact on the right. If such pair of contacts is found, the simulation stops, and the score for a test case is

(number of active contacts on the left which are connected with at least one active contact on the right)

+ (number of active contacts on the right which are connected with at least one active contact on the left)

divided by the number of moves made.

Your overall score will be the sum of your individual scores, divided by the greatest score achieved by anyone for that test case.

If after 2*W*H steps you fail to connect active contacts, the simulation stops, and your absolute score for a test case is 0.

Test Case Generation

W and H are chosen between 10 and 100.

Each character of C chosen as '0' or '1', both values having equal probability.

To generate one square of board, first its type is chosen of the five possible types (no wire, two wires top-bottom, two wires top-right, three wires, four wires), and then its orientation is chosen. If the resulting board already has a connected pair of active contacts on the left and on the right, board (but not W, H or C) is regenerated.

Tools

As usual, a visualizer is available.
 

Definition

    
Class:CircuitConstruction
Method:init
Parameters:int, int, String
Returns:int
Method signature:int init(int W, int H, String C)
 
Method:rotateSquare
Parameters:int[]
Returns:int[]
Method signature:int[] rotateSquare(int[] board)
(be sure your methods are public)
    
 

Notes

-A square can have no wire on it.
-You may return any integer from init, it will be ignored.
-The memory limit is 1 GB and the time limit is 20 seconds (which includes only time spent in your code).
-Invalid return from rotateSquare or time limit results in absolute score 0.
-There are 10 example test cases and 100 full submission test cases.
 

Examples

0)
    
"1"
Returns: "Seed = 1
W = 10
H = 10
C = 
        01000011101101111101"
1)
    
"2"
Returns: 
"Seed = 2
W = 23
H = 50
C = 
        001011011000000111111101011001100100000101100000111101000010
        1100011010111101010001010111101110010000"
2)
    
"3"
Returns: 
"Seed = 3
W = 99
H = 29
C = 
        0111101110110000011101101001110001111110110100111111011101"
3)
    
"4"
Returns: 
"Seed = 4
W = 52
H = 83
C = 
        011000100000111011100100110110111110010010011001010011011111
        000000111011101001010000101111100111010010110111001011111000
        0100111000100011010010001101010101001011011000"
4)
    
"5"
Returns: 
"Seed = 5
W = 83
H = 59
C = 
        011011110010110100111011101001001100000111011100001001010010
        1100111000111010101111111001111010110100101111010110011101"
5)
    
"6"
Returns: 
"Seed = 6
W = 34
H = 36
C = 
        100001010000010100111101001011111000110010101101010011010000
        111010101000"
6)
    
"7"
Returns: 
"Seed = 7
W = 98
H = 54
C = 
        001011010100011110100101101000010000001110000001010011110111
        000110010101110100100101110110100010110110001010"
7)
    
"8"
Returns: 
"Seed = 8
W = 49
H = 30
C = 
        110100001111010110000101110111111101011110010000111001011100"
8)
    
"9"
Returns: 
"Seed = 9
W = 55
H = 74
C = 
        111000111001100011011010011010110010010101110100000101111000
        100001000000011111011000010011100001010011000111001000001000
        0110011110011001001110001011"
9)
    
"10"
Returns: 
"Seed = 10
W = 84
H = 41
C = 
        011011110110001000100001100000110100001101100001101011110000
        0000010010011100101001"

Problem url:

http://www.topcoder.com/stat?c=problem_statement&pm=8604

Problem stats url:

http://www.topcoder.com/tc?module=ProblemDetail&rd=12200&pm=8604

Writer:

Unknown

Testers:

Problem categories:

Simulation