單鏈表的反轉(zhuǎn)問題
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供襄垣網(wǎng)站建設(shè)、襄垣做網(wǎng)站、襄垣網(wǎng)站設(shè)計(jì)、襄垣網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、襄垣企業(yè)網(wǎng)站模板建站服務(wù),十年襄垣做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
單鏈表反轉(zhuǎn)問題經(jīng)常會(huì)遇到。在此記錄一下,以便查閱方便。
如果反轉(zhuǎn)一個(gè)有頭結(jié)點(diǎn)的使用下面的方法比較合適。
//反轉(zhuǎn)單鏈表,此單鏈表帶有頭節(jié)點(diǎn)。 //思想:使用tmp臨時(shí)指針保存頭結(jié)點(diǎn)與鏈表的關(guān)系 typedef struct ListNode { int data; struct ListNode * next; }ListNode,*LinkList; void ReverseList(ListNode* Head) { ListNode *current,*tmp; current = Head->next; if(current != NULL)//反轉(zhuǎn)后第一個(gè)節(jié)點(diǎn)的后繼要為NULL { tmp = current; current = current->next; tmp->next = NULL; } while(current!=NULL) { tmp = current; current = current->next; tmp->next = Head->next; Head->next = tmp; } }
如果沒有頭結(jié)點(diǎn),下面的反轉(zhuǎn)比較合適
//如果沒有頭節(jié)點(diǎn),下面的函數(shù)比較適合 //思想:使用pre和next兩個(gè)指針來記錄當(dāng)前處理的節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn)和后一個(gè)節(jié)點(diǎn)的信息 ListNode * ReverseLinkList(ListNode * head) { ListNode * pre,*next; pre = NULL; next = NULL; while(head) { next = head->next; head->next = pre; pre = head; head = next; } return pre; }