生活随笔
收集整理的這篇文章主要介紹了
kth (1)概述
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
kth既是尋找未排序數(shù)組中第k大的數(shù)
1. 排序法
將數(shù)組排序后,返回第k個(gè)元素。
. 復(fù)雜度
時(shí)間 O(NlogN)
空間 O(1)
2. 優(yōu)先隊(duì)列
遍歷數(shù)組時(shí)將數(shù)字加入優(yōu)先隊(duì)列(堆),一旦堆的大小大于k就將堆頂元素去除,確保堆的大小為k。遍歷完后堆頂就是返回值。
. 復(fù)雜度
時(shí)間 O(NlogK)
空間 O(K)
int findKthLargest(int a[], int nSize, int k)
{ // Creating a min-heap using priority queuepriority_queue<int, vector<int>, greater<int> > q;for (int i = 0; i < nSize; i++) {q.push(a[i]);if (q.size() > k)q.pop();}return q.top();
}void test() {int a[] = { 1, 4, 5, 2, 10, 8 };int aSize = sizeof(a) / sizeof(int); int k = findKthLargest(a, aSize, 3);std::cout << "end" << std::endl;
}
【引用】
[1] 代碼kth.h
總結(jié)
以上是生活随笔為你收集整理的kth (1)概述的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。