zoukankan      html  css  js  c++  java
  • 算法基础~链表~复杂链表(带有随机指针的链表)深度拷贝

    算法基础~链表~复杂链表(带有随机指针的链表)深度拷贝

    ~这题很好的体现了链表遍历的劣势跟数组遍历的优势(有索引,“一击即中”的优势)

    ~链表的遍历访问是需要next标志下个一结点后才能往下一个结点移动;遍历速度很慢;

    ~数组因为有索引下标,通过下标立马可以找到要访问的目标结点;

    1,复杂链表图解:

    2,第一印象思路:若是没有随机指针的标志的话,则简单啦。

    知识点:指针指向~地址【结点地址】

    3,本题难点:因为随机指针的指向而使得链表变得复杂无序化~~~~

    ~解决:无序化,则有序化呀,找出规律!

    (将结点有序化~将结点所在地址“有序化”~~编号id,这样的话,随机指针指向边有“id编号”)

    ---找出一种规律来,就是对结点位置编号化。

    4,id编号化结点位置图解:

    5,过程:第一个结点位置 id = 0;    第二个结点位置 id = 1;   第三个结点位置 id = 2;

                    第四个结点位置 id = 3;  第五个结点位置 id = 4; 第六个结点位置 id = 5;

    【结点位置    id】    这是一种映射呀宝贝,so, map 结构~【结点位置,id】

    6,在结点“编号化”下,咱的存储结构也采用了对应“编号有序化”结构~

    ~ List(有序)的存储结构我们使用的是List 的子类vector。  第一个结点(id = 0)的随机指针指向 id = 2 的结点。”~

    ~则用vector存储结构表达为:vector[0]->random = vector[2].

    7,直接上代码,分析过程如上:

    ps:代码中定义了一个辅助指针 ptr,作用是因为原链表需要被遍历两次,如果只遍历一次的话,头指针移动就够了,

    so,遍历两次原链表,加了一个辅助指针,而头指针不动,才能回头第一个结点

    public class Solution {
      public:
        RandomListNode *copyRandomList(RandomListNode *head){
            std::map<RandomListNode *, int> node_map;
            std::vector<RandomListNode *> node_vector;
            RandomListNode *ptr = head;
            int i = 0;
            while(ptr){
                //vector依次元素装上原链表的结点
                node_vector.push_back(new RandomListNode(ptr->label));
                //初始化map集合,构建【结点位置,id】
                node_map[ptr] = i;
                ptr = ptr->next;
                i++;
            }
            node_vector.push_back(0);
            //ptr指针回到原链表第一个结点
            ptr = head;
            i = 0;
            //把vector中的结点连在一起成一条链,并且同时随机指针的指向标志好
            while(ptr){
                node_vector[i]->next = node_vecotr[i + 1];
                if(ptr->random){
                    int id = node_map[ptr->random];
                    node_vector[i]->random = node_vector[id];
                }
                ptr = ptr->next;
                i++;
            }
            return node_vector[0];
      }
    }
     
     
  • 相关阅读:
    【原创】枚举Android系统的进程、任务和服务的信息
    WPF学习笔记“控件”一:控件基本属性
    WCF学习笔记:基础一
    WPF学习笔记“布局”三:Grid分割窗口
    WPF学习笔记“XAML”一:基础
    WPF学习笔记“窗口”一:入门
    WPF学习笔记“形状”:基础
    WPF学习笔记“窗口”二:入门
    WPF学习笔记“窗口”四:三种方式不规则窗口实现大小的改变
    WPF学习笔记“窗口”三:入门
  • 原文地址:https://www.cnblogs.com/shan333/p/15039043.html
Copyright © 2011-2022 走看看