二维矩阵的常见转换技巧
技巧1:二维矩阵按索引拍平到一维数组
如下图所示,每一个二维矩阵对应的,按第1行到第m行依次排列所得到的一维数组的坐标,可以互相转换
如第2行第3列的16这个数,其矩阵的坐标是(1,2),而映射到一维数组的时候,其对应的下标索引idx=6
idx=6=i*n+j=1*4+2=6
而如何通过idx=6反向得到矩阵的坐标呢?
i=idx/n=6/4 =1
j=idx%n=6%4 =2
得到矩阵的坐标为(i,j) ==>(1,2)
技巧2:将矩阵当成二进制转化成十进制
背景知识
对于十进制整数
x,我们可以用x & 1得到x的二进制表示的最低位,它等价于x % 2:例如当
x = 3时,x的二进制表示为11,x & 1的值为1;例如当
x = 6时,x的二进制表示为110,x & 1的值为0。
对于十进制整数
x,我们可以用x & (1 << k)来判断 x 二进制表示的第k位(最低位为第0位)是否为1。如果该表达式的值大于零,那么第k位为1:例如当
x = 3时,x的二进制表示为11,x & (1 << 1)=11 & 10=10>0,说明第1位为1;例如当
x = 5时,x的二进制表示为101,x & (1 << 1)=101 & 10=0,说明第1位不为1。
举例
给定一个矩阵:
该矩阵如果按每行依次排开的话,可以转换成一维矩阵
将上述的一维矩阵看成一个二进制的数是:
对应的十进制是99
怎么转化
一个矩阵转化成二进制数再转化成十进制数:
一个十进制的数如何转化为二进制的矩阵:
Reference
Last updated