检测单链表是否是回文
生活随笔
收集整理的這篇文章主要介紹了
检测单链表是否是回文
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
如何在不顯式申請額外空間的情況下完成?
設(shè)置兩個指針,一個指針到鏈表末尾時開始回溯,另一個指針開始和這個指針比較
這個代碼有錯誤,1 node1 = node1->next 應(yīng)該加判斷是否為NULL 結(jié)尾;2 node1沒必要遍歷一遍單鏈表,加一個計數(shù),只要遍歷一半就可以了
最直接的做法是用快慢指針
struct NODE {int nVal;NODE* pNext;NODE(int n) : nVal(n), pNext(NULL){} };bool _inner_check(NODE*& pNode1, NODE* pNode2) {if (NULL == pNode2)return true;if (!_inner_check(pNode1, pNode2->pNext))return false;if (pNode2->nVal == pNode1->nVal){pNode1 = pNode1->pNext;return true;}return false; }bool IsPalindromLink(NODE* pHead) {if (NULL == pHead)return false;NODE* pNode = pHead;return _inner_check(pNode, pHead); }總結(jié)
以上是生活随笔為你收集整理的检测单链表是否是回文的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 打印数字回文
- 下一篇: 相同bit1的最大的数