news 2026/6/9 18:51:37

代码随想录算法训练营第四十六天 | 110. 字符串接龙 105.有向图的完全联通 106. 岛屿的周长

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录算法训练营第四十六天 | 110. 字符串接龙 105.有向图的完全联通 106. 岛屿的周长

视频和文字的图 不是广搜过程的图,别看。

写法类型
'a'rune (int32)
"a"string
byte('a')byte (uint8)
s[i]byte
for _, r := range srune
package main import ( "bufio" "fmt" "os" ) func main() { in := bufio.NewReader(os.Stdin) var n int fmt.Fscan(in, &n) var beginStr, endStr string fmt.Fscan(in, &beginStr, &endStr) strSet := make(map[string]struct{}, n) for i := 0; i < n; i++ { var s string fmt.Fscan(in, &s) strSet[s] = struct{}{} } visitMap := make(map[string]int) q := make([]string, 0) q = append(q, beginStr) visitMap[beginStr] = 1 for len(q) != 0 { str := q[0] q = q[1:] for idx, val := range str { bs := []byte(str) for b := 'a'; b <= 'z'; b++ { if val == b { continue } bs[idx] = byte(b) newStr := string(bs) if newStr == endStr { fmt.Println(visitMap[str] + 1) return } if _, ok := strSet[newStr]; ok && visitMap[newStr] == 0 { visitMap[newStr] = visitMap[str] + 1 q = append(q, newStr) } } } } fmt.Println(0) }

注意最后检查是否存在没访问过的结点时,要跳过visited[0]

package main import ( "bufio" "fmt" "os" ) func main() { in := bufio.NewReader(os.Stdin) var n, k int fmt.Fscan(in, &n, &k) gragh := make([][]int, n+1) visited := make([]bool, n+1) for i := range gragh { gragh[i] = make([]int, 0) } for i := 0; i < k; i++ { var s, t int fmt.Fscan(in, &s, &t) gragh[s] = append(gragh[s], t) } visited[1] = true dfs(gragh, visited, 1) for i := 1; i < len(visited); i++ { if !visited[i] { fmt.Println(-1) return } } fmt.Println(1) } func dfs(gragh [][]int, visited []bool, cur int) { for _, next := range gragh[cur] { if !visited[next] { visited[next] = true dfs(gragh, visited, next) } } }

周长是边,不是格子。

package main import ( "bufio" "fmt" "os" ) var dir = [4][2]int{{0, 1}, {1, 0}, {-1, 0}, {0, -1}} func main() { in := bufio.NewReader(os.Stdin) var n, m int fmt.Fscan(in, &n, &m) grid := make([][]int, n) for i := range grid { grid[i] = make([]int, m) for j := range grid[i] { fmt.Fscan(in, &grid[i][j]) } } res := 0 for i := range grid { for j := range grid[i] { if grid[i][j] == 1 { for k := 0; k < 4; k++ { nextI := i + dir[k][0] nextJ := j + dir[k][1] if nextI < 0 || nextI >= len(grid) || nextJ < 0 || nextJ >= len(grid[0]) || grid[nextI][nextJ] == 0 { res++ } } } } } fmt.Println(res) }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 19:11:23

【农业物联网PHP实战】:3步实现设备状态实时同步的终极方案

第一章&#xff1a;农业物联网中设备状态同步的挑战与PHP的优势在农业物联网&#xff08;Agri-IoT&#xff09;系统中&#xff0c;大量传感器和执行器分布在田间地头&#xff0c;实时采集土壤湿度、气温、光照强度等数据&#xff0c;并依赖稳定的状态同步机制确保设备协同工作。…

作者头像 李华
网站建设 2026/6/5 10:24:46

Hz的计数问题总结

前言 看见 mod1e9 7 就跪了&#xff0c;遂写一篇博客把所有的计数问题、组合数学问题都记录下来… 正片 E. Girl Permutation Some permutation of length nnn is guessed. You are given the indices of its prefix maximums and suffix maximums. Recall that a permu…

作者头像 李华
网站建设 2026/6/8 5:35:56

基于单片机的自动售水机的设计与实现

第一章 系统整体设计 基于单片机的自动售水机&#xff0c;核心目标是实现用户自助购水、精准计量与安全供水&#xff0c;整体架构分为支付识别模块、核心控制模块、水量计量模块、供水执行模块及状态显示模块五大单元。支付识别模块负责接收用户投币或扫码支付信号&#xff0c;…

作者头像 李华
网站建设 2026/6/5 10:21:57

【限时掌握】农业产量方差分析三步法:R语言快速建模与可视化

第一章&#xff1a;农业产量方差分析的核心意义 在现代农业科学研究中&#xff0c;理解不同因素对作物产量的影响是优化种植策略的关键。方差分析&#xff08;ANOVA&#xff09;作为一种统计方法&#xff0c;能够有效识别施肥方式、灌溉量、品种差异等处理因素是否对农业产量产…

作者头像 李华
网站建设 2026/6/5 14:25:17

临床数据的R语言生存曲线绘制(从入门到精通全流程拆解)

第一章&#xff1a;临床数据的R语言生存曲线绘制概述在临床研究中&#xff0c;生存分析是评估患者从某一时间点到发生特定事件&#xff08;如死亡、复发&#xff09;时间分布的重要统计方法。R语言凭借其强大的统计计算与图形展示能力&#xff0c;成为实现生存曲线绘制的首选工…

作者头像 李华