力扣每日刷题

138. 随机链表的复制 - 力扣(LeetCode)

这道题主要的问题就是如何确定每个节点的随机指针指向的是哪个节点。只要解决了这个问题那么这道题就解决了。

写题思路(哈希):

不递归:先遍历一遍旧链表,使用哈希表记录每个旧节点和节点在这个链表的下标(和新建的链表对应上),根据旧链表建立新链表并把新链表的前后相连,使用数组按照链表节点在这个链表的位置进行记录。最后在遍历一遍旧链表,获得旧链表的随机节点在哈希表中对应的下标,最后根据下表去数组中取新链表的节点进行连接就好。

代码:

复制代码
public static Node copyRandomList(Node head) {
        if(head==null){
            return null;
        }
        HashMap<Node,Integer> hashMap=new HashMap<>();
        List<Node> list=new ArrayList<>();
        int i=0;
        Node pre=head.next;
        Node p=new Node(head.val);
        list.add(p);
        hashMap.put(head,i);
        i++;
        while(pre!=null){
            hashMap.put(pre,i);
            Node now=new Node(pre.val);
            list.add(now);
            p.next=now;
            p=p.next;
            pre=pre.next;
            i++;
        }
        p=list.getFirst();
        while(head!=null){
            if(head.random!=null) {
                int k = hashMap.get(head.random);
                p.random = list.get(k);
            }
            p=p.next;
            head=head.next;
        }
        return list.getFirst();
}

递归:使用哈希表记录每个旧链表节点和对应的新链表结点,对于每个节点都可以进行判断,如果这个节点不在哈希表中,我们就创建一个新链表节点,并把旧链表的next节点和random节点作为参数进行传入。最后返回创建好的新节点。

代码:

复制代码
public static Node copyRandomList(Node head,int i){
        if(head==null){
            return null;
        }
        if(!map.containsKey(head)){
            Node node=new Node(head.val);
            map.put(head,node);
            node.next=copyRandomList(head.next);
            node.random=copyRandomList(head.random);
        }
        return map.get(head);
}
相关推荐
傻瓜搬砖人21 小时前
c语言绿皮书第三版第十一章习题
c语言·开发语言·算法·谭浩强·绿皮书第三版
计算机安禾21 小时前
【c++面向对象编程】第3篇:类与对象(二):构造函数与析构函数
开发语言·c++·算法
小年糕是糕手21 小时前
【C++】vector 不踩坑指南:用法、底层实现与迭代器失效解析
c++·算法
SilentSamsara1 天前
生成器完全指南:`yield` 与惰性求值的工程价值
linux·开发语言·python·算法·机器学习·青少年编程
玛卡巴卡ldf1 天前
【LeetCode 手撕算法】(二分查找)搜索插入位置、搜索二维矩阵、查找数组相同的所有位置、搜索旋转排序数组、旋转升序数组的最小值
数据结构·算法·leetcode
谷雨不太卷1 天前
进程的状态码
java·前端·算法
散峰而望1 天前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
躺不平的理查德1 天前
时间复杂度与空间复杂度备忘录
数据结构·算法
yaki_ya1 天前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
刃神太酷啦1 天前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode