存在一个m*n的二维数组,其成员取值范围为0,1,2。其中值为1的元素具有同化特性,每经过1s,将周围上下左右值为0的元素同化为1,而值为2的元素免疫同化。将数组所有成员随机同化成0或2,再将矩阵的[0,0]元素修改成1,在经过足够长的时间后,求矩阵中有多少个元素是0或2(即0和2的数量之和)输入描述:输入的两个数字是矩阵大小,后面的数字是矩阵内容;输出描述:返回矩阵中非1的元素个数 ,样例 input 4 4 0 0 0 0 0 2 2 2 0 2 0 0 0 2 0 0 output 9
时间: 2024-02-29 21:56:08 浏览: 115
好的,这是一个比较有趣的问题,我会尽力回答。
首先,我们可以将初始矩阵中所有的1周围的0同化成1,将所有的1和2保持不变。这可以通过遍历矩阵中的每一个元素来实现。具体实现方法如下:
1. 遍历整个矩阵,将所有值为1的元素的周围值为0的元素同化成1。
2. 对于值为2的元素,将其标记为“免疫”。
3. 对于值为0的元素,将其标记为“未同化”。
4. 将矩阵中的[0,0]元素修改为1。
接下来,我们可以按照以下步骤进行模拟:
1. 对于所有未被标记为“免疫”的元素,将其周围值为1的元素同化成1。
2. 将所有未被标记为“免疫”的元素标记为“已同化”。
3. 继续重复步骤1和步骤2,直到所有未被标记为“免疫”的元素都被同化成1。
4. 统计矩阵中值为0或2的元素个数,即为所求。
以下是完整的代码实现:
阅读全文