[TYVJ] P2031「Poetize9」升降梯口
时间: 1000ms / 空间: 131072KiB / Java类名: Main
背景
一些探险家组队去探索神秘的Nescafe之塔。经过一番周折,探险队员们终于突破了塔门,来到了Nescafe之塔的一层大殿。而探险队员们想要拜访的四大护法和塔之圣主据传都住在塔的高层,因此他们迅速奔向了大殿一侧的升降梯口。不过由于Nescafe之塔乃是一年一度封印和开启“Nescafe之杯”的禁地,自然不能允许外来人员随意闯入,因此要想乘坐升降梯,队员们必须破解开启升降梯动力的密码。
描述
升降梯的密码盘是一个由n*n个方格组成的正方形(n为偶数),第i行第j列的方格中标着数字(i-1)*n+j,而在密码盘的上面覆盖着一张同样由n*n个方格组成的挡光片。如果挖去挡光片上的n*n/4个格子,并从小到大记下通过挖去的格子看到的n*n/4个数;然后把挡光片顺时针旋转90°、180°、270°,每次也同样记下看到的n*n/4个数;这样最终将得到n*n个数。如果记下的这n*n个数恰好是1~n*n的一个排列,那么我们称这片挖去n*n/4个格子后的挡光片对密码盘是“精确覆盖”的。不妨用一个n*n的01矩阵表示这张挡光片,其中挖去的格子为1,没有挖去的格子为0,那么如下图所示的挡光片就可以表示为:
0000
0000
1101
0001
起初能看到:9 10 12 16,旋转90°后看到2 6 13 14,旋转180°看到1 5 7 8,旋转270°看到3 4 11 15。
定义挡光片A比挡光片B小,当且仅当A对应的01矩阵的字典序小于B对应的01矩阵的字典序(即:A和B对应的01矩阵中存在一个位置(x,y),使得矩阵A、B中前x-1行的所有数字以及第x行的前y-1个数字都相同,而A中第x行第y列的数字为0,B中第x行第y列的数字为1)。
现在升降梯口的墙上写着一个数字k,探险队员们必须迅速制作出第k小的、对密码盘“精确覆盖”的挡光片,用以在密码盘上获取n*n个数作为开启升降梯动力的密码。
输入格式
一行两个正整数n、k。
输出格式
输出满足要求的挡光片对应的01矩阵。
测试样例
输入
4 15
输出
0000
0000
1101
0001
备注
测试点编号 | n | k |
---|---|---|
1 | n=2 | k<=10 |
2 | n=2 | k<=10^3 |
3 | n=4 | k<=10 |
4 | n=4 | k<=10^9 |
5 | n=6 | k<=10 |
6 | n=6 | k<=10^18 |
7 | n=8 | k<=10 |
8 | n=8 | k<=10^18 |
9 | n=10 | k<=10^18 |
10 | n=10 | k<=10^18 |
数据保证有解。