C語言(CED)輸出前k大的數(分治法/局部快速排序):給定一個數組,統計前k大的數并且把這k個數從大到小輸出。

)輸出前k大的數(分治法/局部快速排序):給定一個數組,統計前k大的數并且把這k個數從大到小輸出。

[輸入]

第一行包含一個整數n,表示數組的大小。

第二行包含n個整數,表示數組的元素,整數之間以一個空格分開。第三行包含一個整數k。k < n。

[輸出]

從大到小輸出前k大的數,每個數一行。

[樣例輸入]

10

4 5 6 9 8 7 1 2 3 0

5

[樣例輸出]

9

8

7

6

5?

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
int a[1000];
void quick_sort(int a[], int start, int end)
{if (start<end){int s = a[start];int i = start;int j = end;//剛開始排序從右向左查找才可以while (i<j){//從右向左查找第一個小于s的值與a[0]交換while (i<j&&a[j] >= s)j--;if (i<j)a[i++] = a[j];//把a[j]的值給a[i],并讓i向后走一位//從左向右查找第一個大于等于s的值與a[0]交換while (i<j&&a[i]<s)i++;if (i<j){a[j--] = a[i];//把a[i]的值給此時s所在的地址,并讓j向前退一位}}a[i] = s;//因為在之前的交換值過程中a[i]的值已經不是最初的值,所以要變回來quick_sort(a, start, i - 1);//排序樞軸前數列quick_sort(a, i + 1, end);//排序樞軸后數列}
}
int main()
{int n;//輸入n個數字scanf("%d", &n);int i = 0;//用于存儲數字時的循環計數for (i = 0; i<n; i++) //將n個數字存入數組中scanf("%d", &a[i]);int k;scanf("%d", &k);quick_sort(a, 0, n - 1);//快速排序函數調用for (i = n - 1; k>0; k--, i--) //循環輸出排序結果printf("%d\n", a[i]);system("pause");return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531099.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531099.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531099.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C語言(CED)最長公共子序列----動態規劃第一題

一、動態規劃算法與分治法的異同 相同點&#xff1a; A、二者均是將待求解的問題分成若干子問題來求解。 B、二者在編寫代碼的時候&#xff0c;都要用到遞歸。 不同點&#xff1a; A、分治法求解的問題&#xff0c;在將問題分成若干子問題之后&#xff0c;其子問…

C語言(CED)01背包——動態規劃第二題

一、問題描述 給定n種物品和一個背包。物品i的質量Wi&#xff0c;其價值Vi&#xff0c;背包的容量為c。問如何選擇裝入背包中的物品&#xff0c;使得裝入背包中的物品總價值最大&#xff1f; 二、解題思想 01背包和最長公共子序列都是動態規劃題目中求最優解的問題&#xff0…

C語言(CED)gameboy接餡餅問題

一、題目大意 都說天上不會掉餡餅&#xff0c;但有一天gameboy正走在回家的小徑上&#xff0c;忽然天上掉下大把大把的餡餅。這餡餅別處都不掉&#xff0c;就掉落在他身旁的10米范圍內。餡餅如果掉在了地上當然就不能吃了&#xff0c;所以gameboy馬上卸下身上的背包去接。但由…

C語言(CED)遞歸實現漢諾塔問題

一、問題大意 大梵天創造世界的時候做了三根金剛石柱子&#xff0c;在一根柱子上從下往上按照大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規定&#xff0c;任何時候&#xff0c;在小圓盤上都不能放大圓盤&#xff0c;…

C語言(CED)智力大沖浪——貪心算法第一題

一、題目大意 小偉報名參加中央電視臺的智力大沖浪節目&#xff0c;本次挑戰賽吸引了眾多參賽者&#xff0c;主持人為了表彰大家的勇氣&#xff0c;先獎勵每個參賽者m元。先不要太高興&#xff01;因為這些錢還不一定都是你的&#xff01;接下來主持人宣布了比賽規則&#xff…

C語言(CED)鋼條最優切割收益

目錄 一、題目大意 二、大致思路 三、具體實現 一、題目大意 一家公司購買長鋼條&#xff0c;將其切割成短鋼條出售&#xff0c;切割本身沒有成本&#xff0c;長度為i的短鋼條的價格為Pi。那給定一段長度為n的鋼條和一個價格表Pi,求鋼條的切割方案使得收益Rn最大。提示&…

C語言(CED)如何用sort函數根據結構體里的某一屬性進行排序

&#xff08;請先看置頂博文&#xff09;本博打開方式&#xff0c;請詳讀_liO_Oil的博客-CSDN博客_怎么把androidstudio卸載干凈 前幾天在編寫代碼的時候&#xff0c;突然要根據結構體的屬性進行從小到大的排序&#xff0c;這即是我寫這篇文章的導火索。 正如大家所知…

撰寫paper時,如何在word里輸入圖片或其他文獻(PDF)里的公式?(更新時間2022.03.01)

我們在寫paper時&#xff0c;經常會遇到在Word里編寫數學公式的問題&#xff0c;其中大多數公式是已經存在的&#xff0c;所以只需要識別、復制、粘貼即可&#xff0c;那么接下來&#xff0c;我就介紹一下“Mathtype”“Mathpix”的方法&#xff0c;分為所需軟件、軟件操作、公…

家里接入某運營商300M寬帶,為何網速還是很慢?(還未裝修房屋的請進來)

&#xff08;請先看置頂博文&#xff09;本博打開方式&#xff0c;請詳讀_liO_Oil的博客-CSDN博客_怎么把androidstudio卸載干凈 引言&#xff1a;家里接入300M的寬帶&#xff0c;但是自我感覺網速不佳&#xff0c;遂結合所學知識&#xff0c;對此問題進行分析、研究和調察&…

(CED)列指針與行指針的聯系與區別

一、列指針&#xff08;豎為列&#xff09; 1、列指針相關定義 列指針&#xff1a;被稱為是指針變量指向二維數組的某個元素 一般使用時會有如下定義&#xff1a; int a[3][4]{1,2,3,4,5,6,7,8,9,10,11,12}; int *p;而上述代碼定義的指針p&#xff0c;一般按照下表方式指向…

C語言(CED)C語言中雙引號和單引號的區別

最簡單的區別&#xff1a; 在字符型變量賦初值時&#xff0c;用單引號&#xff1b;為字符串變量賦初值時用雙引號&#xff01; 具體區別&#xff1a; 1、大小 單引號引起的一個字符&#xff0c;其大小為1個Byte。 雙引號引起的字符串&#xff0c;因為在其結尾需加一個二進…

一、Pytho第一課——Python安裝及配置路徑方法(最詳細小白教程,沒有之一。如若不懂,不是還可以私信嘛!對吧?)

目錄 一、下載軟件 二、安裝 三、編輯器 四、在Pycharm上成功運行Python程序&#xff08;配置Python解釋器&#xff09; 一、下載軟件 官方下載地址&#xff1a;https://www.python.org/downloads/&#xff08;打開似乎很吃力&#xff0c;必要時刻“掛燈”&#xff09; …

二、Python第二課——變量命名規則及字符串變量相關函數

目錄 一、變量命名規則 二、字符串變量及相關函數 1、字符串變量 2、相關函數 最后瑣碎雜物&#xff1a; 1、字符串之間的拼接 2、字符串格式控制&#xff08;制表符和換行&#xff09; 一、變量命名規則 正如其他編程語言一樣&#xff0c;程序離不開聲明變量&#x…

三、Python第三課——Python中數字的用法及編碼原則(Python禪意)

目錄 一、Python中的數字 1、整數 2、浮點數 3、整數、浮點數和字符串的聯系和區別 二、編碼原則 1、為代碼增加注釋 2、Python 禪意 A、編碼精美 B、避繁就簡 C、無簡就繁 D、使用常規方法解決問題 E、先有效、再精巧、逐步升華 一、Python中的數字 編程中&#…

四、Python第四課——Python中列表及其操作(增刪改查)

目錄 一、Python中的列表 1、列表的定義和賦值 2、列表的使用 二、列表的“增刪改查” 1、列表中元素的增加 A、在列表尾添加元素 B、在列表中插入元素 2、列表中“元素的刪除” A、使用del語句刪除元素 B、使用pop()函數刪除元素 C、彈出列表中任何位置元素…

五、Python第五課——Python中組織列表的相關函數

目錄 一、用sort()函數對列表進行永久排序 二、用sorted()函數對列表進行臨時排序 三、用reverse()函數對列表進行列表原始排序的逆序輸出 四、使用len()函數確定列表長度 創建列表后&#xff0c;內部的元素逐漸增多&#xff0c;其排列順序也是無法預測的&#xff0c;因為…

如何正確下載、安裝Codeblocks?

目錄 一、Codeblocks的下載 二、Codeblocks的安裝 三、Codeblocks的運行 相信很多同學在初學C語言時都會選擇一個短小精悍的代碼編輯器&#xff0c;如CodeBlocks&#xff08;不說別的了&#xff0c;直接切入正題&#xff09;。 在2020年&#xff08;今年&#xff09;3月份-…

Python:創建列表,其中包含數字1-1000000,為什么Pycharm控制臺結果顯示不完整?

目錄 一、問題描述&#xff08;尋找解決方法的同學直接看“標題二”&#xff09; 二、解決辦法 一、問題描述&#xff08;尋找解決方法的同學直接看“標題二”&#xff09; 在學習Python過程中遇到一個這樣的問題&#xff0c;也算是一個小BUG吧。題目大意是這樣的&#xff…

六、Python第六課——Python中的for循環及數字列表

目錄 一、Python中的for循環 1、for循環語句的聲明。 2、for循環縮進常見問題 二、數字列表 1、函數range() 2、使用range()函數創建數字列表 3、使用一系列函數處理數字列表&#xff08;統計&#xff09; 4、列表解析&#xff08;生成列表的簡潔方法&#xff09; 一…

七、Python第七課——有關列表的二三事(切片、切片的遍歷和復制)

目錄 一、切片 二、遍歷切片 三、列表的復制 一、切片 此前&#xff0c;我們學習了如何訪問單個列表以及如何處理列表中的所有元素&#xff0c;那么我們如何處理列表中的部分元素呢&#xff1f;這就引出一個概念“切片” 。我們可以把列表看成是面包&#xff0c;“切片”…