這篇文章將為大家詳細(xì)講解有關(guān)LeetCode如何實(shí)現(xiàn)部分鏈表反轉(zhuǎn),小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),順慶企業(yè)網(wǎng)站建設(shè),順慶品牌網(wǎng)站建設(shè),網(wǎng)站定制,順慶網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,順慶網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
部分鏈表反轉(zhuǎn)。
1)鏈表為空或者一個(gè)節(jié)點(diǎn)時(shí),返回即可
2)獲取鏈表長(zhǎng)度,進(jìn)行m,n范圍檢查。
3)head部分保留m節(jié)點(diǎn)之前的鏈表。second保留[m,n]之間的節(jié)點(diǎn),包括m,n兩個(gè)節(jié)點(diǎn)。next保留n節(jié)點(diǎn)后的節(jié)點(diǎn)。
4)使用**list方便給第一部分的結(jié)束結(jié)束后置NULL。first是方便第二段鏈表的處理。
/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */ struct ListNode* reverseBetween(struct ListNode* head, int m, int n) { if ( head == NULL || head->next == NULL ) { return head; } int len = 0; struct ListNode *pLen = head; for ( ; pLen; pLen = pLen->next ) { len++; } if ( m < 1 || n > len ) { return head; } struct ListNode *first = head; struct ListNode **list = &head; int cnt = 1; for ( ; cnt < m; cnt++ ) { list = &(*list)->next; first = first->next; } *list = NULL; struct ListNode *second = NULL; struct ListNode *next = NULL; for ( ; cnt <= n; cnt++ ) { next = first->next; first->next = second; second = first; first = next; } first = head; while ( first != NULL && first->next != NULL ) { first = first->next; } if ( head != NULL ) { first->next = second; } else { head = second; } first = head; while ( first != NULL && first->next != NULL ) { first = first->next; } first->next = next; return head; }
關(guān)于“LeetCode如何實(shí)現(xiàn)部分鏈表反轉(zhuǎn)”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。