C++數據結構與算法之判斷一個鏈表是否為回文結構的方法
本文實例講述了C++判斷一個鏈表是否為回文結構的方法。分享給大家供大家參考,具體如下:
題目:
給定一個鏈表頭節(jié)點head,請判斷是否為回文結構
例如:
1->2->1 true
1->2->2->1 true
1->2->3->4->2->1 false
解題思路及代碼
1、找到鏈表中間節(jié)點,然后將鏈表中間節(jié)點的右邊所有節(jié)點放入一個棧中。
2、然后從鏈表首節(jié)點和棧頂元素一一對比,不相等則return false。
算法C++代碼:
鏈表節(jié)點結構定義
typedef struct Node
{
int data;
struct Node* next;
}node, *pLinkedList;
bool isHuiWen(pLinkedList head)
{
if (head == NULL || head->next == NULL)
return true;
pLinkedList right = head->next;//保存中間節(jié)點的下一個節(jié)點(若為偶數則為偏右的中間節(jié)點)
pLinkedList cur = head; //快指針
while (cur->next != NULL && cur->next->next != NULL)
{
right = right->next;
cur = cur->next->next;
}
//當鏈表總結點個數為奇數情況時:
if (cur->next != NULL && cur->next->next == NULL)
right = right->next;
//將鏈表右邊的節(jié)點放入一個棧中
stack<pLinkedList>* s = new stack<pLinkedList>();
while (right != NULL)
{
s->push(right);
right = right->next;
}
//比較鏈表左右兩邊節(jié)點是否相等
while (!s->empty())
{
if (head->next->data != s->top()->data)
return false;
s->pop();
head = head->next;
}
return true;
}
希望本文所述對大家C++程序設計有所幫助。
上一篇:C++使用遞歸和非遞歸算法實現的二叉樹葉子節(jié)點個數計算方法
欄 目:C語言
本文標題:C++數據結構與算法之判斷一個鏈表是否為回文結構的方法
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1601.html
您可能感興趣的文章
- 04-02c語言沒有round函數 round c語言
- 01-10數據結構課程設計- 解析最少換車次數的問題詳解
- 01-10數據結構課程設計-用棧實現表達式求值的方法詳解
- 01-10深入理解C++中常見的關鍵字含義
- 01-10使用C++實現全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現DBSCAN聚類算法
- 01-10全排列算法的非遞歸實現與遞歸實現的方法(C++)
- 01-10深入理解atoi()與itoa()函數的用法
- 01-10C++大數模板(推薦)


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


