麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Java > 正文

編碼實現從無序鏈表中移除重復項(C和JAVA實例)

2019-11-26 15:55:28
字體:
來源:轉載
供稿:網友

如果不能使用臨時緩存,你怎么編碼實現?

復制代碼 代碼如下:

方法一:不使用額外的存儲空間,直接在原始鏈表上進行操作。首先用一個指針指向鏈表頭節點開始,然后遍歷其后面的節點,將與該指針所指節點數據相同的節點刪除。然后將該指針后移一位,繼續上述操作。直到該指針移到鏈表。

void delete_duplicate1(node* head){
    node*pPos=head->next;
    node*p,*q;
    while(pPos!=NULL){//用pPos指針來指示當前移動到什么位置了
        p=pPos;
       q=pPos->next;
       while(q!=NULL){//遍歷pPos后面的所有節點,找出節點值與pPos所指節點相同的節點,將其刪除
            if(pPos->data==q->data){
                node*pDel=q;
                p->next=q->next;
                q=p->next;
                free(pDel);
                }
            else{
                p=q;
                q=q->next;
                }
            }
        pPos=pPos->next;
        }
}


方法二:如果允許使用額外的空間,則能通過空間換時間,來降低算法的復制度。可以使用hash表來完成,既然是面試題,我們這里可以暫時先不考慮使用hash可能帶來的一些問題,先假設它是完美的。即假設它能將任意整數hash到一定范圍,不會出現負數下標,不會出現hash沖突等。
復制代碼 代碼如下:

void delete_duplicate2(node* head)
{
    node*p=head->next;
    node*q=p->next;
    memset(hash,0,sizeof(hash));
    hash[p->data]=1;//置為1,表示該數已經出現過
    while(q!=NULL){
        if(hash[q->data]!=0){
            node*pDel=q;
            p->next=q->next;
            q=p->next;
            free(pDel);
            }
        else{
            hash[q->data]=1;//置為1,表示該數已經出現過
            p=q;
            q=q->next;
            }
        }
}

JAVA參考代碼:

復制代碼 代碼如下:

public static void deleteDups(LinkedListNode n) {
  Hashtable table = new Hashtable();
  LinkedListNode previous = null;
  while (n != null) {
    if (table.containsKey(n.data)) previous.next = n.next;
    else {
      table.put(n.data, true);
      previous = n;
    }
    n = n.next;
  }
}
public static void deleteDups2(LinkedListNode head) {
    if (head == null) return;
    LinkedListNode previous = head;
    LinkedListNode current = previous.next;
    while (current != null) {
      LinkedListNode runner = head;
      while (runner != current) { // Check for earlier dups
        if (runner.data == current.data) {
          LinkedListNode tmp = current.next; // remove current
          previous.next = tmp;
          current = tmp; // update current to next node
          break; // all other dups have already been removed
        }
        runner = runner.next;
      }
      if (runner == current) { // current not updated - update now
        previous = current;
        current = current.next;
      }
    }
 }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久亚洲第一 | 久久免费精品视频 | 91网视频| 国产又白又嫩又紧又爽18p | 色999国产 | 国产成人av一区 | 国产成人精品免费视频大全办公室 | 久久经典免费视频 | 黄片毛片一级 | 久久精品一级 | 久久久久女人精品毛片九一 | 成人男男视频拍拍拍在线观看 | 国产一级淫片a级aaa | 高清视频91 | 成人精品一区二区三区中文字幕 | 国产精品一区在线免费观看 | 国产91影院| 久久一区二区三区av | 精品亚洲一区二区三区 | 久草在线资源福利站 | 国产精品v片在线观看不卡 成人一区二区三区在线 | 国产精品成人一区二区三区吃奶 | 日韩高清影视 | 亚洲成人在线视频网站 | 亚洲第九十九页 | 成年免费大片黄在线观看岛国 | 爱射av | 欧美精品免费一区二区三区 | 中文字幕精品在线播放 | 国产老师做www爽爽爽视频 | 精品成人免费一区二区在线播放 | 草久影视 | 特级黄一级播放 | 欧美日韩一 | 91短视频网页版 | www.guochanav.com| 99精品视频免费看 | 91精品视频网址 | 一区二区三区视频在线观看 | 国产九色视频在线观看 | 精品在线观看一区 |