luogu#P6411. [COCI2008-2009#3] MATRICA

[COCI2008-2009#3] MATRICA

题目描述

您需要构造一个 n×nn\times n 字符矩阵 MM

这个字符矩阵有如下几条限制:

  1. Mi,j=Mj,i(1i,jn)M_{i,j}=M_{j,i}(1\le i,j\le n)
  2. 必须恰好含有 aia_i 个字符 cic_i

因为构造的方案有很多种,所以你需要输出方案中字典序最小的。

因为输出太多不好,所有你只需要输出 pp 列,具体的方案将会在输入格式中声明。

如果无解,请输出 IMPOSSIBLE

输入格式

第一行为两个整数 nnkkkk 表示限制 22 的条数。

接下来 kk 行,每一行为一个大写字母和一个整数,分别为 cic_iaia_i

接下来一行为一个整数 pp

接下来一行 pp 个整数,表示你需要输出的列的标号,保证按升序出现。

输出格式

为一个 nnpp 列的字符矩阵,如果无解,请输出 IMPOSSIBLE

3 3
A 3
B 2
C 4
3
1 2 3 

AAB
ACC
BCC 

4 4
A 4
B 4
C 4
D 4
4
1 2 3 4 

AABB
AACC
BCDD
BCDD 
4 5
E 4
A 3
B 3
C 3
D 3
2
2 4 

AC
BE
DE
ED 

4 6
F 1
E 3
A 3
B 3
C 3
D 3
4
1 2 3 4 

IMPOSSIBLE 

提示

数据范围与限制

  • 对于 60%60\% 的数据,保证 n300n\le 300
  • 对于 80%80\% 的数据,保证 n3×103n\le 3\times 10^3
  • 对于 100%100\% 的数据,保证 1n3×1041\le n\le 3\times 10^41k261\le k\le 26ai=n2\sum a_i=n^2cicjc_i\neq c_j1p501\le p\le 50

说明

本题译自 Croatian Open Competition in Informatics 2008/2009 Contest #3 T4 MATRICA。