按行删除二进制数组中的连通组件的高效算法
创始人
2024-08-22 05:30:09
0

算法思路:

  1. 定义一个指针p指向当前行的第一个元素
  2. 对于每一行,循环扫描该行的所有元素
  3. 如果当前元素为1,则对其进行标记
  4. 若当前元素的左边或上边或右上角或左上角有被标记的1,则将当前元素也标记为1
  5. 如果当前元素和它的相邻部分已经标记为1,则将它们变成0,从而在数组中删除一个连通组件
  6. 继续扫描下一个元素

代码示例:

# 定义一个指针p指向当前行的第一个元素
p = 0
# 循环扫描每一行
for i in range(rows):
    # 循环扫描该行的所有元素
    for j in range(cols):
        # 如果当前元素为1,则对其进行标记
        if arr[i][j] == 1:
            arr[i][j] = 2
            # 如果当前元素的左边或上边或右上角或左上角有被标记的1,则将当前元素也标记为1
            if i > 0 and arr[i-1][j] > 1:
                arr[i][j] = arr[i-1][j]
            if j > 0 and arr[i][j-1] > 1:
                arr[i][j] = arr[i][j-1]
            if i > 0 and j > 0 and arr[i-1][j-1] > 1:
                arr[i][j] = arr[i-1][j-1]
            if i > 0 and j < cols - 1 and arr[i-1][j+1] > 1:
                arr[i][j] = arr[i-1][j+1]
            # 如果当前元素和它的相邻部分已经

相关内容

热门资讯

黑科技挂!德州软件辅助(黑科技... 黑科技挂!德州软件辅助(黑科技ai)原先有挂(有挂脚本)-哔哩哔哩;科技安装教程;136704302...
黑科技存在!wepoke辅助技... 黑科技存在!wepoke辅助技巧(智能ai)原先真的是有挂(有挂最新款)-哔哩哔哩,支持语音通讯、好...
黑科技辅助!cloudpoke... 黑科技辅助!cloudpoker有辅助透视么(黑科技)先前真的是有挂(有挂透明挂)-哔哩哔哩;玩家必...
黑科技科技!德州ai神器下载(... 黑科技科技!德州ai神器下载(辅助挂)其实有挂(有挂辅助挂)-哔哩哔哩1、点击下载安装,微扑克wpk...
黑科技安卓版!cloudpok... 黑科技安卓版!cloudpoker云扑克(透视)本来真的有挂(有挂打法)-哔哩哔哩;最新版2024是...
黑科技智能ai!wepoke软... 自定义wepoke软件俱乐部系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器...
黑科技脚本!微扑克ai辅助实战... 黑科技脚本!微扑克ai辅助实战效果(ai辅助)确实真的有挂(有挂ai代打)-哔哩哔哩;实战中需综合运...
黑科技系统!wpk透视辅助合作... 黑科技系统!wpk透视辅助合作(黑科技)最初是真的有挂(有挂俱乐部)-哔哩哔哩;人气非常高,ai更新...
黑科技安卓版!wepoke透明... 黑科技安卓版!wepoke透明挂要多少钱(黑科技ai)切实存在有挂(有挂软件)-哔哩哔哩;1分钟了解...
黑科技辅助挂!微扑克辅助神器(... 黑科技辅助挂!微扑克辅助神器(透明挂)原来是有挂(有挂挂)-哔哩哔哩1、玩家可以在微扑克辅助神器软件...