栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

岛的个数问题

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

岛的个数问题




func countIsLand(m [][]int) int {
	if m == nil || m[0] == nil {
		return 0
	}
	N := len(m)
	M := len(m[0])
	res := 0
	for i := 0; i < N; i++ {
		for j := 0; j < M; j++ {
		   if m[i][j] == 1 {
			   res++
			   infect(m,i,j,N,M)
		   }
		}
	}
	return res
}

func infect(m [][]int, i, j, N, M int)  {
	if i < 0 || i >= N || j < 0 || j >= M || m[i][j] != 1 {
		return
	}
	m[i][j] = 2
	infect(m,i+1,j, N,M)
	infect(m,i-1,j, N,M)
	infect(m,i,j+1, N,M)
	infect(m,i,j-1, N,M)
}

func TestCountIsLand(t *testing.T)  { // O(N*M)
	mp := [][]int{
		{1,1,1,1,0,0,1,1,1,1},
		{1,1,1,0,1,0,1,1,1,0},
		{0,1,1,1,1,0,1,1,0,1},
		{0,0,0,0,0,1,0,0,1,1},
		{1,0,0,1,1,0,1,0,1,1},
		{1,0,1,1,0,0,1,1,1,1},
	}
	t.Log(countIsLand(mp))
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/663929.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号