激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務器之家 - 編程語言 - Java教程 - 編碼實現(xiàn)從無序鏈表中移除重復項(C和JAVA實例)

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

2019-10-18 12:50java教程網(wǎng) Java教程

如果不能使用臨時緩存,你怎么實現(xiàn)無序鏈表中移除重復項(?C和JAVA實例無序鏈表中移除重復項。

crosoft YaHei";"> 如果不能使用臨時緩存,你怎么編碼實現(xiàn)?

復制代碼代碼如下:


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

 

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后面的所有節(jié)點,找出節(jié)點值與pPos所指節(jié)點相同的節(jié)點,將其刪除
            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可能帶來的一些問題,先假設它是完美的。即假設它能將任意整數(shù)hash到一定范圍,不會出現(xiàn)負數(shù)下標,不會出現(xiàn)hash沖突等。

復制代碼代碼如下:

void delete_duplicate2(node* head)
{
    node*p=head->next;
    node*q=p->next;
    memset(hash,0,sizeof(hash));
    hash[p->data]=1;//置為1,表示該數(shù)已經(jīng)出現(xiàn)過
    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,表示該數(shù)已經(jīng)出現(xiàn)過
            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;
      }
    }
 }

延伸 · 閱讀

精彩推薦
282
主站蜘蛛池模板: 成年性羞羞视频免费观看无限 | 久久精品片 | 深夜福利视频免费观看 | 亚洲福利在线视频 | 欧美一级高清片在线 | 性猛交ⅹxxx乱巴西 在线播放中文 | 国产精品久久久久国产精品三级 | 黄色a级片视频 | 97超碰资源站 | 在线中文字幕亚洲 | 一区二区精品视频 | 亚洲国产精品一 | 免费毛片小视频 | 久久久综 | 91精品国产乱码久久桃 | 国产一级一国产一级毛片 | 黄色1级视频 | 黄色成年在线观看 | 在线观看国产一区二区 | 国产精品一区二区在线 | 久久久久久久免费精品 | 看91视频 | 欧美.com | 精品国产91久久久久久久妲己 | 精品一区二区三区在线观看国产 | 国产午夜精品久久久久 | 亚洲最黄视频 | 日韩欧美激情视频 | 美女很黄很黄免费的 | 久久精品黄 | 特一级黄色毛片 | 成人毛片在线观看 | 精品国产91久久久 | 精品亚洲综合 | 久久99久久99精品 | 草莓视频在线导航 | 中国国语毛片免费观看视频 | 青青国产在线视频 | 亚洲第五色综合网 | 在线成人精品视频 | 蜜桃精品视频 |