在兩個有序鍊錶中查詢第K大元素。

2021-06-21 05:12:37 字數 826 閱讀 4258

這是一次面試的時候,別人問我的,當時回答的不太好。

題目描述:

即在兩個有序鍊錶中查詢第k大的元素,相等的元素做乙個元素處理。

, ,這是簡單的情況,查詢第2大的元素則是 2。

,,稍微複雜,查詢第3大元素則是3,第4大元素 則是4.

解答:其實我們可以借鑑合併有序鍊錶的方法來解決這個問題。

演算法實現如下:

[cpp]view plain

copy

print?

struct

node;    

typedef

node* list;    

intfindkthelement(list &list1, list &list2, 

intk)    

else

if(plist1->data > plist2->data)  

else

p = p->next;  

}  p = plist2->next;  

while

(p)  

p = p->next;  

}  }  

if(count == k)  

}    

if(plist1 == null && plist2 == null)  

list rest = (plist1 != null) ? plist1 : plist2;  

while

(rest)  

rest = rest->next;  

}  return

-1;  

}   

在鍊錶中查詢倒數第k個元素

第一種思路 第二種思路 注意 檔名 listnode.h pragma once ifndef listnode h define listnode h include using namespace std 定義鍊錶結構體 templatet struct listnode listnode t ...

鍊錶 合併兩個有序鍊錶

標籤 鍊錶 題目描述 輸入兩個單調遞增的鍊錶,輸出兩個鍊錶合成後的鍊錶,當然我們需要合成後的鍊錶滿足單調不減規則。解題思路 兩種解法 遞迴和非遞迴 拓展 參考 public listnode merge listnode list1,listnode list2 else 非遞迴 public li...

合併兩個有序鍊錶

鍊錶的題目總是讓我很惆悵。動輒就會runtime error。比如這題,額外用了乙個節點的空間來儲存頭節點。我很不情願多用這個空間,不過貌似不行。貌似不行,實際可行,見附錄。把頭節點提出迴圈 實現類 class solution else if l1 null p next l1 if l2 nul...