欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 会展 > 算法刷题之路之链表初探(四)

算法刷题之路之链表初探(四)

2025/9/2 13:42:15 来源:https://blog.csdn.net/aoyuanyuan0921/article/details/140430979  浏览:    关键词:算法刷题之路之链表初探(四)

算法刷题之路之链表初探(四)

今天来学习的算法题是leecode138随机链表的赋值,是一道简单的入门题,话不多说!直接上!

条件

在这里插入图片描述

代码

/*
// Definition for a Node.
class Node {int val;Node next;Node random;public Node(int val) {this.val = val;this.next = null;this.random = null;}
}
*/class Solution {public Node copyRandomList(Node head) {if(head == null){return null;}Node cur = head;HashMap<Node,Node> map = new HashMap<>();while(cur!=null){//建立新链表和旧链表的对应关系(1对1)map.put(cur,new Node(cur.val));cur = cur.next;}cur=head;while(cur!=null){//map.get(cur)是获取到新链表中的node节点。//因为是一对以的对应关系,所以旧节点的next就等于新节点的next//所以只需要拿到旧节点对应的next值赋值给新节点就完成了新节点的next属性的赋值map.get(cur).next=map.get(cur.next);//随机链表也是一样的道理map.get(cur).random=map.get(cur.random);cur=cur.next;}return map.get(head);}
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词