golang力扣leetcode 133.克隆图

该博客介绍了如何使用深度优先搜索实现图的克隆,即创建一个与原图完全相同的副本。通过建立一个映射表记录已拷贝的节点,遍历原始图的每个节点并复制其链接,从而实现图结构的深拷贝。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

133.克隆图

133.克隆图

题解

深拷贝,用一个map记录有没有拷贝过对应的节点即可,map的key是原始节点,val是克隆节点

代码

package main

type Node struct {
	Val       int
	Neighbors []*Node
}

func cloneGraph(node *Node) *Node {
	visited := make(map[*Node]*Node)
	return dfsClone(node, visited)
}
func dfsClone(node *Node, visited map[*Node]*Node) *Node {
	if node == nil {
		return nil
	}
	if val, ok := visited[node]; ok {
		return val
	}
	cloneNode := &Node{
		Val:       node.Val,
		Neighbors: make([]*Node, len(node.Neighbors)),
	}
	visited[node] = cloneNode
	for i := 0; i < len(node.Neighbors); i++ {
		cloneNode.Neighbors[i] = dfsClone(node.Neighbors[i], visited)
	}
	return cloneNode
}
func main() {

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cheems~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值