删除链表中所有重复元素

public ListNode deleteDuplication(ListNode pHead){
  //LinkedHashMap可以按照输入的顺序进行输出
  LinkedHashMap<Integer,Integer> map = new LinkedHashMap<>();
  ListNode current = pHead;
  while(current != null){
    if(!map.containsKey(current.val)){
      map.put(current.val,1);
    }else{
      int times = map.get(current.val);
      times++;
      map.put(current.val,times);
    }
    current = current.next;
  }

  ListNode newHead = null;
  ListNode point = null;
  boolean isHead = true;
  set<Integer> set = map.keySet();
  Iterator<Integer> it = set.iterator();

  //根据map中的值,只用出现一次的值来构造新表
  while(it.hasNext()){
    int temp = it.next();
    if(map.get(temp) == 1){
      ListNode currentNode = new ListNode(temp);
      if(isHead){
        newHead = curentNode;
        point = currentNode;
        isHead = false;
        continue;
      }
      point.next = currentNode;
      point = currentNode;
    }
  }
  return newHead;
}

 

posted @ 2019-03-26 14:15  strawqqhat  阅读(156)  评论(0编辑  收藏  举报
#home h1{ font-size:45px; } body{ background-image: url("放你的背景图链接"); background-position: initial; background-size: cover; background-repeat: no-repeat; background-attachment: fixed; background-origin: initial; background-clip: initial; height:100%; width:100%; } #home{ opacity:0.7; } .wall{ position: fixed; top: 0; left: 0; bottom: 0; right: 0; } div#midground{ background: url("https://i.postimg.cc/PP5GtGtM/midground.png"); z-index: -1; -webkit-animation: cc 200s linear infinite; -moz-animation: cc 200s linear infinite; -o-animation: cc 200s linear infinite; animation: cc 200s linear infinite; } div#foreground{ background: url("https://i.postimg.cc/z3jZZD1B/foreground.png"); z-index: -2; -webkit-animation: cc 253s linear infinite; -o-animation: cc 253s linear infinite; -moz-animation: cc 253s linear infinite; animation: cc 253s linear infinite; } div#top{ background: url("https://i.postimg.cc/PP5GtGtM/midground.png"); z-index: -4; -webkit-animation: da 200s linear infinite; -o-animation: da 200s linear infinite; animation: da 200s linear infinite; } @-webkit-keyframes cc { from{ background-position: 0 0; transform: translateY(10px); } to{ background-position: 600% 0; } } @-o-keyframes cc { from{ background-position: 0 0; transform: translateY(10px); } to{ background-position: 600% 0; } } @-moz-keyframes cc { from{ background-position: 0 0; transform: translateY(10px); } to{ background-position: 600% 0; } } @keyframes cc { 0%{ background-position: 0 0; } 100%{ background-position: 600% 0; } } @keyframes da { 0%{ background-position: 0 0; } 100%{ background-position: 0 600%; } } @-webkit-keyframes da { 0%{ background-position: 0 0; } 100%{ background-position: 0 600%; } } @-moz-keyframes da { 0%{ background-position: 0 0; } 100%{ background-position: 0 600%; } } @-ms-keyframes da { 0%{ background-position: 0 0; } 100%{ background-position: 0 600%; } }