文章責編:張曉1
看了本文的網友還看了學歷| 高考 中考 考研 自考 成考 外語| 四六級 職稱英語 商務英語 公共英語 資格| 公務員 報關員 銀行 證券 司法 導游 教師 計算機| 等考 軟考
工程|一建 二建 造價師 監(jiān)理師 咨詢師 安全師 結構師 估價師 造價員 會計| 會計證 會計職稱 注會 經濟師 稅務師 醫(yī)學| 衛(wèi)生資格 醫(yī)師 藥師 [更多]
用C++實現(xiàn)合并排序
合并排序的思想:當只有一個元素時終止排序,超過一個元素的話,將所有元素分成大致相同的兩個集合,分別對兩個集合進行排序,最后將排好序的子集合合并為所要求的排好序的集合。
在最壞情況下,時間復雜度為O(nlogn),它是一個漸進的最優(yōu)算法。
#include
#include
//這個函數將b[0]至b[right-left+1]拷貝到a[left]至a[right]
template
void Copy(T a[],T b[],int left,int right)
{
int size=right-left+1;
for(int i=0;i { a[left++]=b[i]; } } //這個函數合并有序數組a[left:i],a[i+1:right]到b,得到新的有序數組b template
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |