国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

快排求第k大

2019-11-11 07:32:20
字體:
供稿:網(wǎng)友
/*設(shè)某次排序后,分界點x右邊有p個元素,(此時x左邊元素皆小于等于x,右邊元素皆大于等于x)若p == k-1,則 x 為恰第 k 大;若p < k-1,則在區(qū)間[left, i) 之間求第 k-p-1 大若p > k-1,則在區(qū)間[i+1, right) 之間求第k大*/#include <cstdio>int qsort(int* A, int left, int right, int k){//在左閉右開區(qū)間[left, right)求第k大 int i = left, j = right - 1; int tmp = A[left]; while(i < j){ while(A[j] >= tmp && i < j) j--;//從右往左第一個比tmp小的數(shù) if(i < j) A[i++] = A[j]; while(A[i] <= tmp && i < j) i++;//從左往右第一個比tmp大的數(shù) if(i < j) A[i] = A[j--]; } A[i] = tmp; int p = right - i - 1;//A[i]右邊有p個元素 if(p == k-1) return tmp; if(p < k-1) return qsort(A, left, i - 1, k - p - 1); if(p > k-1) return qsort(A, i + 1, right, k);}int main(){ int n, k; while(scanf("%d%d", &n, &k)==2){ int* A = new int[n+1]; for(int i = 0; i < n; i++) scanf("%d", &A[i]); //int A[10] = {13,16,2,1,-1,6,54,123,32,-90}; int ans = qsort(A, 0, n, k);//求第k大
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 四会市| 河北省| 东平县| 临邑县| 房产| 绩溪县| 寿阳县| 老河口市| 滨海县| 明溪县| 汶川县| 兰坪| 麟游县| 会泽县| 甘孜县| 济宁市| 大英县| 嘉祥县| 岳普湖县| 富平县| 浮山县| 宜章县| 孟连| 夏河县| 章丘市| 白银市| 盖州市| 邵东县| 宁明县| 峨眉山市| 会东县| 闵行区| 卢湾区| 民丰县| 嘉善县| 德令哈市| 阿拉善盟| 惠州市| 黄梅县| 噶尔县| 都兰县|