题解 | #删除链表中重复的结点#

删除链表中重复的结点

http://www.nowcoder.com/practice/fc533c45b73a41b0b44ccba763f866ef

先用hash记录次数

function ListNode(x){
    this.val = x;
    this.next = null;
}
function deleteDuplication(pHead)
{
    // write code here
    let myMap=new Map()
    let p=pHead
    while(p){
        if(myMap.has(p.val)){
        myMap.set(p.val,myMap.get(p.val)+1)    
    }else{
        myMap.set(p.val,1)
    }
        p=p.next
    }
    let res=new ListNode(0)
    res.next=pHead
    let cur=res
    while(cur.next){
        if(myMap.get(cur.next.val)!==1){
           cur.next=cur.next.next
           }else{
            cur=cur.next
        }
    }
    return res.next
    
}
module.exports = {
    deleteDuplication : deleteDuplication
};
全部评论

相关推荐

牛客928043833号:在他心里你已经是他的员工了
点赞 评论 收藏
分享
04-06 11:24
已编辑
太原学院 C++
真烦好烦真烦:感觉不太对劲,这种主动加微信的一般都是坑,要小心辨别
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务