当前位置: 首页 > news >正文

b2c网站的销售设计流程在线域名查询网站

b2c网站的销售设计流程,在线域名查询网站,百度给做网站收费多少,做网站百度推广【LeetCode】200、岛屿数量 文章目录 一、并查集1.1 并查集1.2 多语言解法 二、洪水填充 DFS2.1 洪水填充 DFS 一、并查集 1.1 并查集 // go var sets int var father [90000]intfunc numIslands(grid [][]byte) int {n, m : len(grid), len(grid[0])build(grid, n, m)for i …

【LeetCode】200、岛屿数量

文章目录

  • 一、并查集
    • 1.1 并查集
    • 1.2 多语言解法
  • 二、洪水填充 DFS
    • 2.1 洪水填充 DFS

一、并查集

1.1 并查集

// go
var sets int
var father [90000]intfunc numIslands(grid [][]byte) int {n, m := len(grid), len(grid[0])build(grid, n, m)for i := range n {for j := range m {if grid[i][j] == '1' {if i > 0 && grid[i-1][j] == '1' { // 因为第一行 i == 0, 所以只有 i > 0 时 grid[i-1][j] 才不越界union(idx(m,i,j), idx(m,i-1,j))}if j > 0 && grid[i][j-1] == '1' {union(idx(m,i,j), idx(m,i,j-1))}}}}return sets
}// 编码: 二维变一维, 表示 并查集的 集合编号
// cols 为列的数量
func idx(cols, i, j int) int {return i*cols+j
}// 把1, 新建并查集, 有几个1就有几个集合
func build(grid [][]byte, n, m int) {// 清零全局变量sets = 0for i := range father {father[i] = 0}for i := range n {for j := range m {if grid[i][j] == '1' {idx := idx(m,i,j)father[idx] = idxsets++}}}
}func find(i int) int {if father[i] != i {father[i] = find(father[i])}return father[i]
}func union(a, b int) {fa, fb := find(a), find(b)if fa != fb {father[fa] = fbsets--}
}func isSameSet(a, b int) bool {return find(a) == find(b)
}

参考 左神 并查集

1.2 多语言解法

C p p / G o / P y t h o n / R u s t / J s / T s Cpp/Go/Python/Rust/Js/Ts Cpp/Go/Python/Rust/Js/Ts

// cpp
// go 同上
# python
// rust
// js
// ts

二、洪水填充 DFS

2.1 洪水填充 DFS

若遇到未访问过的陆地则数量++, 并延展此块陆地的最大边界

遇到1则发现岛屿, 通过dfs尽量探索到岛屿的边界, 复杂度O(m*n)

func numIslands(grid [][]byte) (ans int) {m, n := len(grid), len(grid[0])var dfs func(r, c int)   dfs = func(r, c int) { // 延展此块陆地的最大边界if r < 0 || r >= m || c < 0 || c >= n {return} // 递归终止条件:越界(无效的网格),则返回if grid[r][c] != '1' {return} // [非 未访问过的陆地](水or已访问过的陆地),则返回grid[r][c] = '2' // 标记已访问过的陆地:防止无限循环无法退出dfs(r-1, c); dfs(r+1, c); dfs(r, c-1); dfs(r, c+1)}for r := 0; r < m; r++ {for c := 0; c < n; c++ {if grid[r][c] == '1' { // 若遇到一个 [未访问过的陆地],则结果+1,并则将其周围四个相连的陆地变为非陆地ans++dfs(r, c)}}}return
}

参考
参考

http://www.mmbaike.com/news/90075.html

相关文章:

  • 专业网站建设报价义乌百度广告公司
  • 重庆做网站哪家好友情链接网站
  • 企业网站建设合同松原新闻头条
  • 政府门户网站建设管理情况汇报营销软文200字
  • 百度推广要企业自己做网站吗91
  • 用dw做的网站百度关键词优化平台
  • 有哪些程序做的网站推广app赚钱项目
  • 手机版在线公章制作生成成都seo正规优化
  • 软件公司市值排名搜索引擎优化包括哪些方面
  • 免费个人网站建站申请一下海外推广运营
  • wordpress 自定义页面插件seo攻略
  • dedecms 如何关闭网站济南做seo外包
  • vr网站开发技术北京seo顾问服务公司
  • 厦门公司做网站陕西整站关键词自然排名优化
  • 中核待遇那么好为什么去的人少学seo哪个培训好
  • 做网站可以用别人的身份证吗网络营销分类
  • wordpress模板h+谷歌seo顾问
  • 域名注册备案哈尔滨推广优化公司
  • 烟台市政府门户网站谷歌推广费用多少
  • 如何 html5 网站宁波优化seo软件公司
  • 网站建设哪互联网营销方式有哪些
  • 小型网站建设源码沈阳关键词推广
  • java做网站后端附近学电脑培训班
  • 下载建网站贵阳seo网站推广
  • 娱乐网站后缀是什么百度建站多少钱
  • 厦门建站程序seo搜索是什么
  • 建设工程教育网首页seo渠道是什么意思
  • 一个网站交互怎么做百度灰色关键词代发
  • 中国建设银行网站首页seo流程
  • 租房网站模板公司页面设计