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

首頁 > 學院 > 開發設計 > 正文

快排求第k大

2019-11-11 06:59:53
字體:
來源:轉載
供稿:網友
/*設某次排序后,分界點x右邊有p個元素,(此時x左邊元素皆小于等于x,右邊元素皆大于等于x)若p == k-1,則 x 為恰第 k 大;若p < k-1,則在區間[left, i) 之間求第 k-p-1 大若p > k-1,則在區間[i+1, right) 之間求第k大*/#include <cstdio>int qsort(int* A, int left, int right, int k){//在左閉右開區間[left, right)求第k大 int i = left, j = right - 1; int tmp = A[left]; while(i < j){ while(A[j] >= tmp && i < j) j--;//從右往左第一個比tmp小的數 if(i < j) A[i++] = A[j]; while(A[i] <= tmp && i < j) i++;//從左往右第一個比tmp大的數 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大
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 蜜桃视频在线播放 | 亚洲第一男人天堂 | xxxxhd73国产| 国产精品久久久久久久久久 | 日韩精品网站在线观看 | 国产精品久久久久久久久久东京 | 久国产| 欧美大电影免费观看 | 久久久久久久网站 | 2级毛片 | 人人舔人人舔 | 成人毛片免费 | 黄色特级一级片 | 成年人在线视频免费 | 亚洲影院在线 | 91在线视频免费观看 | 国产精品国产成人国产三级 | 精国品产一区二区三区有限公司 | 在线成人av| 一级大片一级一大片 | 欧美a在线 | 国产精品亚洲精品久久 | 欧美精品网址 | 国产日韩在线 | 日韩精品无码一区二区三区 | 可以看逼的视频 | 姑娘第四集免费看视频 | 草草久| 新久草在线视频 | 成年免费视频黄网站在线观看 | 亚洲3p激情在线观看 | 亚洲国产中文字幕 | 亚洲视频在线一区二区 | 久久av喷吹av高潮av懂色 | 国产精品视频 | 久久久久久免费 | 毛片久久 | 欧美成人三级视频 | 一本色道久久综合亚洲精品图片 | 日日鲁夜夜视频热线播放 | 影视免费观看 |