左神算法书籍《程序员代码面试指南》——2_06判断一个链表是否为回文结构

Posted zzw1024

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了左神算法书籍《程序员代码面试指南》——2_06判断一个链表是否为回文结构相关的知识,希望对你有一定的参考价值。

【题目】
给定一个链表的头节点head,请判断该链表是否为回文结构。
例如:
1->2->1,返回true。
1->2->2->1,返回true。
15->6->15,返回true。
1->2->3,返回false。
进阶:
如果链表长度为N,时间复杂度达到O(N),额外空间复杂度达到O(1)。
【题解】
方法一:
遍历一遍链表,将数据压入栈中
然后再遍历一遍链表与栈的弹出数据对比
方法二:
使用快慢指针,将链表的前部分压入栈,然后栈数据弹出与链表的后半部分对比
方法三:
使用快慢指针,将链表的后半部分反转,然后与链表前半部分对比

 

  1 #include<iostream>
  2 #include <vector>
  3 #include <stack>
  4 
  5 using namespace std;
  6 
  7 struct Node
  8 
  9     int val;
 10     Node* next;
 11     Node(int a = 0) :val(a), next(nullptr) 
 12 ;
 13 
 14 bool Way1(Node* head)
 15 
 16     stack<int>s;
 17     Node* p = head->next;
 18     while (p)
 19     
 20         s.push(p->val);
 21         p = p->next;
 22     
 23     p = head->next;
 24     while (!s.empty())
 25     
 26         if (p->val != s.top())
 27             return false;
 28         p = p->next;
 29         s.pop();
 30     
 31     return true;
 32 
 33 bool Way2(Node* head)
 34 
 35     Node *p, *q;
 36     stack<int>s;
 37     p = q = head->next;
 38     while (q && q->next)
 39     
 40         p = p->next;
 41         q = q->next->next;
 42     
 43     if (q)
 44         p = p->next;
 45     while (p)
 46     
 47         s.push(p->val);
 48         p = p->next;
 49     
 50     p = head->next;
 51     while (!s.empty())
 52     
 53         if (p->val != s.top())
 54             return false;
 55         p = p->next;
 56         s.pop();
 57     
 58     return true;
 59 
 60 bool Way3(Node* head)
 61 
 62     Node *p, *q, *pre=nullptr;
 63     stack<int>s;
 64     p = q = head->next;
 65     while (q && q->next)
 66     
 67         pre = p;
 68         p = p->next;
 69         q = q->next->next;
 70     
 71     if (q)
 72     
 73         pre = p;
 74         p = p->next;
 75     
 76     pre->next = nullptr;
 77     while (p)
 78     
 79         q = p->next;
 80         p->next = pre->next;
 81         pre->next = p;
 82         p = q;
 83     
 84     p = head->next;
 85     while (pre->next)
 86     
 87         if (p->val != pre->next->val)
 88             return false;
 89         p = p->next;
 90         pre = pre->next;
 91     
 92     return true;    
 93 
 94 
 95 int main()
 96 
 97     Node* head = new Node(-1);
 98     Node* p = head;
 99     vector<int>v;
100     v =  1,2,2,1 ;
101     for (auto a : v)
102     
103         Node* q = new Node(a);
104         p->next = q;
105         p = q;
106     
107     cout << Way1(head) << endl;
108     cout << Way2(head) << endl;
109     cout << Way3(head) << endl;
110     
111     return 0;
112 

 

以上是关于左神算法书籍《程序员代码面试指南》——2_06判断一个链表是否为回文结构的主要内容,如果未能解决你的问题,请参考以下文章

左神算法书籍《程序员代码面试指南》——2_12将搜索二叉树转换成双向链表

左神算法书籍《程序员代码面试指南》——3_02打印二叉树的边界节点★★

左神算法书籍《程序员代码面试指南》——1_01设计一个有getMin功能的栈

左神算法书籍《程序员代码面试指南》——2_12将搜索二叉树转换成双向链表★★

左神算法书籍《程序员代码面试指南》——2_07将单向链表按某值划分成左边小中间相等右边大的形式

左神算法书籍《程序员代码面试指南》——1_10最大值减去最小值小于或等于num的子数组数量