400382: GYM100155 H Connecting Islands

Memory Limit:256 MB Time Limit:1 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

H. Connecting Islandstime limit per test1 secondmemory limit per test256 megabytesinputstandard inputoutputstandard output

The civil war in the Bytelandian ocean has ended. The two Bytelandian islands have decided to unite forming the United Kingdom of Bytelandia. One of the first concerns of the newly chosen government is transportation.

Prior to the war each of the 2 islands had a perfect network of transportation. On any given island, every city was connected by a train to every other city. Connections are bidirectional. During the war, some train lines were disrupted and thus, the trains on these lines were suspended. On any island, no more than 15 trains were suspended. In addition to rerunning the disrupted trains, the government has to form inter-island ferry connections. The ferries will connect every city X to every city Y, given that X and Y are not on the same island. Commuting between cities on the same island will only be via trains.

In Bytelandia, everything is binary, including train and ferry ticket prices. A ticket costs either 0 or 1 units of currency. The government decided not to change any ticket prices for trains that were not disrupted during the war. It will assign ticket costs to the trains suspended during the war and to all ferry lines. Priding themselves in being strong mathematicians, Bytelandians have decided to design the ticket system such that for any 3 distinct cities X, Y and Z,

C(X, Y) + C(Y, Z)  ≥  C(X, Z)

where C(X, Y) is the ticket price of getting from X to Y (by train if they belong to the same island or by ferry otherwise).

You are given a description of the Bytelandian islands, your goal is to figure out a costs assignment if it is possible.

Input

The input consists of the description of both islands (one after the other). The description of one island starts with one line containing one integer Ck represents the number of cities in this island, followed by Ck lines each one contains Ck characters (1  ≤  Ck  ≤  100). Each character is '0', '1' or 'x'. The jth character of the ith line is the price of the train ticket from city i to city j on that island. A price 'x' means that it is one of the suspended train lines. Each Ck by Ck table is guaranteed to be symmetric (table[i][j] = table[j][i] for each different i and j), and each table will have a diagonal of '0's (table[i][i] = '0' for each different i), also each table will contain no more than 30 'x's (15 different trains, because each train will be mentioned twice in the table).

Note that the input might contain 3 different cities in the same islands and the trains connecting them are not suspended, and these 3 cities don't satisfy the described condition above.

Output

If there is no way to do the costs assignment satisfying the conditions described above, output on a single line "NO" (without the quotes). Otherwise, print "YES" (without the quotes) on the first line followed by C1 + C2 lines each one contains C1 + C2 characters (C1 is the number of cities in the first island, and C2 is the number of cities in the second island). The jth character on the ith line is the cost of getting from city i to city j (by train if they belong to the same island or by ferry otherwise). In the output, the cities on the first island are numbered from 1 to C1 (inclusive) while the cities in the second island are numbered from C1 + 1 to C1 + C2 (inclusive). If there is more than one correct solution, print anyone of them.

Note that you can't change the costs given in the input, and the output table must be symmetric.

ExamplesInput
3
011
10x
1x0
2
01
10
Output
YES
01101
10011
10011
01101
11110
Input
2
0x
x0
4
010x
1010
0100
x000
Output
NO

加入题单

上一题 下一题 算法标签: