2017-08-13 149 views
-7

给定两个二进制矩阵m1和m2,与m1相比,m2保证具有更大或相等的尺寸(在两个维度上)。用C++编写一个函数来计算m2内m1的外观。 例如在大二进制矩阵中计算小二进制矩阵的外观

m1 = [1 1; 11],m2 = [1 0 0; 1 1 0 0; 0 0 1 1 0 0 1 1]

然后M1中平方米出现2次,则该函数将返回整数2.

任何人都可以使用一个基于位操作方法有效地解决这个问题?

+3

SO不是代码写入服务。 –

+0

仍在等待您遇到的问题。 –

+1

你所做的任何尝试? –

回答

0

如果使用运行长度编码来表示二进制模式,则问题将转换为与压缩表示匹配的一个普通字符串,并且不需要任何操作。

然后您可以使用Boyer-Moore这样的标准算法,当发现不匹配时,您可以使用所有行中找到的最长偏移。

+0

直觉上,我想过使用位技巧,因为2个矩阵是二进制矩阵。但是我后来意识到,简单地将矩阵的行转换为无符号的长长整数具有大小限制。感谢字符串匹配的想法! –