C語言數(shù)據(jù)結(jié)構(gòu) 鏈表與歸并排序?qū)嵗斀?/h1>
來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊: 次
C語言數(shù)據(jù)結(jié)構(gòu) 鏈表與歸并排序?qū)嵗斀?/strong>
歸并排序適合于對鏈表進(jìn)行原址排序,即只改變指針的連接方式,不交換鏈表結(jié)點的內(nèi)容。
歸并排序的基本思想是分治法:先把一個鏈表分割成只有一個節(jié)點的鏈表,然后按照一定順序、自底向上合并相鄰的兩個鏈表。
只要保證各種大小的子鏈表是有序的,那么最后返回的鏈表就一定是有序的.
歸并排序分為分割和合并兩個子過程。分割是用遞歸的方法,把鏈表對半分割成兩個子鏈表;合并是在遞歸返回(回朔)的時候,把兩個有序鏈表合并成一個有序鏈表。
(注意:只有一個節(jié)點的鏈表一定是有序的)
這里sort過程就是分割過程;merge過程就是合并且排序的過程
說到分割鏈表,那么問題來了:鏈表不是隨機(jī)訪問的,我怎么知道分割點在哪里?一個寶貴的經(jīng)驗就是:維護(hù)兩個指針,一快一慢。快指針每次后移兩個單位,慢指針每次只移動一個單位。當(dāng)快指針移動到tail或者最后一個有效節(jié)點時,慢指針就指向了中間的節(jié)點。
sort過程:
Node* sort (Node* beg)
{
if(beg==tail || beg->next==tail) return beg;
Node* a = beg; Node* b = beg->next;
while(b!=tail && b->next != tail)
{
a = a->next; b = b->next->next;
}
b = a->next; //the beginning of right part
a->next = tail; //the end of left part
return merge(sort(beg), sort(b));
}
把鏈表分割之后就要合并。merge操作傳入的參數(shù)是兩個有序鏈表,返回的是合并后的有序的鏈表。兩個有序鏈表簡單拼接之后不一定是有序的,需要對每一個元素重排。這個重排的過程是從兩個鏈表各自最?。ㄗ畲螅┰亻_始,誰?。ù螅┚桶颜l放到新的鏈表里。
Node* LinkedList<T>::merge(Node* a, Node* b)
{
Node dummy = Node();
Node* head = &dummy;
// temp是正在合并的表的節(jié)點
Node* temp = head;
while(a!=tail && b!=tail) //逐個比較鏈表a和鏈表b的每個元素
{
if(a->data <= b->data)
{
// 如果a比b小, 那么當(dāng)前結(jié)點的后繼就是a
temp->next = a;
// 把當(dāng)前節(jié)點移向后繼
temp = a;
// a后移
a = a->next;
}
else
{
temp->next = b;
temp = b;
b = b->next;
}
// 如果原表a已經(jīng)排完,那么新表后面就放b的剩余元素
// 否則仍然以a為標(biāo)準(zhǔn)和b進(jìn)行比較
temp->next = (a==tail) ? b : a;
}
return head->next;
}
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
C語言數(shù)據(jù)結(jié)構(gòu) 鏈表與歸并排序?qū)嵗斀?/strong>
歸并排序適合于對鏈表進(jìn)行原址排序,即只改變指針的連接方式,不交換鏈表結(jié)點的內(nèi)容。
歸并排序的基本思想是分治法:先把一個鏈表分割成只有一個節(jié)點的鏈表,然后按照一定順序、自底向上合并相鄰的兩個鏈表。
只要保證各種大小的子鏈表是有序的,那么最后返回的鏈表就一定是有序的.
歸并排序分為分割和合并兩個子過程。分割是用遞歸的方法,把鏈表對半分割成兩個子鏈表;合并是在遞歸返回(回朔)的時候,把兩個有序鏈表合并成一個有序鏈表。
(注意:只有一個節(jié)點的鏈表一定是有序的)
這里sort過程就是分割過程;merge過程就是合并且排序的過程
說到分割鏈表,那么問題來了:鏈表不是隨機(jī)訪問的,我怎么知道分割點在哪里?一個寶貴的經(jīng)驗就是:維護(hù)兩個指針,一快一慢。快指針每次后移兩個單位,慢指針每次只移動一個單位。當(dāng)快指針移動到tail或者最后一個有效節(jié)點時,慢指針就指向了中間的節(jié)點。
sort過程:
Node* sort (Node* beg) { if(beg==tail || beg->next==tail) return beg; Node* a = beg; Node* b = beg->next; while(b!=tail && b->next != tail) { a = a->next; b = b->next->next; } b = a->next; //the beginning of right part a->next = tail; //the end of left part return merge(sort(beg), sort(b)); }
把鏈表分割之后就要合并。merge操作傳入的參數(shù)是兩個有序鏈表,返回的是合并后的有序的鏈表。兩個有序鏈表簡單拼接之后不一定是有序的,需要對每一個元素重排。這個重排的過程是從兩個鏈表各自最?。ㄗ畲螅┰亻_始,誰?。ù螅┚桶颜l放到新的鏈表里。
Node* LinkedList<T>::merge(Node* a, Node* b) { Node dummy = Node(); Node* head = &dummy; // temp是正在合并的表的節(jié)點 Node* temp = head; while(a!=tail && b!=tail) //逐個比較鏈表a和鏈表b的每個元素 { if(a->data <= b->data) { // 如果a比b小, 那么當(dāng)前結(jié)點的后繼就是a temp->next = a; // 把當(dāng)前節(jié)點移向后繼 temp = a; // a后移 a = a->next; } else { temp->next = b; temp = b; b = b->next; } // 如果原表a已經(jīng)排完,那么新表后面就放b的剩余元素 // 否則仍然以a為標(biāo)準(zhǔn)和b進(jìn)行比較 temp->next = (a==tail) ? b : a; } return head->next; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
欄 目:C語言
下一篇:C#復(fù)制和深度復(fù)制的實現(xiàn)方法
本文標(biāo)題:C語言數(shù)據(jù)結(jié)構(gòu) 鏈表與歸并排序?qū)嵗斀?/a>
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1799.html
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對數(shù)怎么表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10C#中split用法實例總結(jié)
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實現(xiàn)頁面的局部加載