首页 > 其他 > 详细

复杂链表的复制

时间:2016-06-28 12:52:41      阅读:170      评论:0      收藏:0      [点我收藏+]

题目

输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点)

解题

HashMap
先next链接
再random链接

/*
public class RandomListNode {
    int label;
    RandomListNode next = null;
    RandomListNode random = null;

    RandomListNode(int label) {
        this.label = label;
    }
}
*/
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
public class Solution {
    public RandomListNode Clone(RandomListNode pHead)
    {
        HashMap<RandomListNode,RandomListNode> map = new HashMap<RandomListNode,RandomListNode>();
        RandomListNode p = pHead;
        RandomListNode q = new RandomListNode(-1);
        // next 链接
        while(p!=null){
            RandomListNode t = new RandomListNode(p.label);
            map.put(p, t);
            p = p.next;
            q.next = t;
            q = t;
        }
        Set<Entry<RandomListNode,RandomListNode>> set = map.entrySet();        
        // random 链接
        for(Entry<RandomListNode,RandomListNode> s:set){
             Entry<RandomListNode, RandomListNode> next = s;            
            next.getValue().random = map.get(next.getKey().random);
        }

        return map.get(pHead);
    }
}

复杂链表的复制

原文:http://blog.csdn.net/qunxingvip/article/details/51735096

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!