news 2026/5/8 18:55:23

代码随想录算法训练营第四十六天 | 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/5/4 4:22:35

PHP 8.6 JIT缓存如何影响生产环境?3个真实案例告诉你真相

第一章&#xff1a;PHP 8.6 JIT缓存机制的演进与核心原理PHP 8.6 在性能优化方面迈出了关键一步&#xff0c;其对JIT&#xff08;Just-In-Time&#xff09;编译器的改进不再局限于运行时代码生成&#xff0c;而是引入了持久化的JIT缓存机制。这一机制显著降低了重复请求中JIT编…

作者头像 李华
网站建设 2026/5/4 18:15:16

基于单片机的太阳能自动追光系统

第一章 系统开发背景与意义 在全球能源转型背景下&#xff0c;太阳能作为清洁能源的利用率持续提升&#xff0c;但固定安装的太阳能板存在能量转换效率低的问题——当阳光与面板法线夹角偏离10时&#xff0c;发电效率下降约15%。传统手动调整方式难以实时追踪太阳轨迹&#xff…

作者头像 李华
网站建设 2026/5/1 9:47:10

Java毕设项目:基于SpringBoot的工厂生产设备故障维修维护管理系统基于springboot工厂生产设备维护管理系统的设计(源码+文档,讲解、调试运行,定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/5 12:28:19

Laravel 13事件监听新纪元:如何同时处理HTTP、WebSocket与队列事件?

第一章&#xff1a;Laravel 13 的多模态事件监听Laravel 13 引入了多模态事件监听机制&#xff0c;允许开发者通过多种传输方式响应同一事件&#xff0c;例如 HTTP、WebSocket、队列和命令行输出。这一特性增强了系统的响应灵活性&#xff0c;使应用能够根据运行环境动态选择最…

作者头像 李华
网站建设 2026/5/6 4:27:18

一个下午,我折腾出了一个 Code Review 的 Skill

一个下午&#xff0c;我折腾出了一个 Code Review 的 Skill踩了个大坑&#xff0c;但挺值起因 事情是这样的。 我手头有两个之前写的小工具&#xff1a;一个能分析代码里的 API 调用流程&#xff0c;画成时序图&#xff1b;另一个能从 Git 里捞变更内容。某天下午我突然想到&am…

作者头像 李华