C++最简单的方法,遍历存在vector<int> ivec容器中,然后头尾对应比较

O(n)时间,O(n)空间

 /**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
bool isPalindrome(ListNode* head) {
if(head==NULL) return true;
ListNode* cur=head;
vector<int> ivec;
while(cur){
ivec.push_back(cur->val);
cur=cur->next;
}
for(int i=;i<ivec.size()--i;i++){
int j=ivec.size()--i;
if(ivec[i]!=ivec[j]) return false;
}
return true;
}
};

C++进阶方法:使用O(n)时间,O(1)空间,对前一半元素链表指向进行翻转,然后从中间到两边遍历判断,缺点是更改了原来的链表,好处是没有占用额外存储空间;

 /**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
bool isPalindrome(ListNode* head) {
if(head==NULL||head->next==NULL) return true;
ListNode* cur,*pre;
cur=head;
int length=;
while(cur!=NULL){
length+=;
cur=cur->next;
}
cur=head->next;pre=head;head->next=NULL;
for(int i=;i<(length+)/;i++){
ListNode* temp;
temp=cur->next;
cur->next=pre;
pre=cur;
cur=temp;
}
if(length%==) pre=pre->next;
while(cur!=NULL){
if(cur->val==pre->val){
cur=cur->next;pre=pre->next;
}
else return false;
}
return true;
}
};

最新文章

  1. IIS错误处理集合
  2. ubuntu pip 安装django报错解决
  3. 微信开发jssdk入门
  4. 计算纯文本情况下RichTextBox实际高度的正确方法(.NET)
  5. 解决Hibernate向MySQL数据库插入中文乱码问题
  6. newCachedThreadPool线程池
  7. sql中with as的用法练习
  8. 1215.1——动态分配内存的补充realloc
  9. Java 多态,重载,重写
  10. 一种动态写入apk数据的方法(用于用户关系绑定、添加渠道号等)
  11. C++中:(*p)++和*(p++)和*p++的区别
  12. 利用Tarjan算法解决(LCA)二叉搜索树的最近公共祖先问题——数据结构
  13. nginx反向代理中proxy_set_header 运维笔记
  14. 关于Java课堂实验中的一些总结(Scanner)
  15. JAVA动手动脑及课后作业
  16. python绘制树枝
  17. Java并发编程(2) AbstractQueuedSynchronizer的内部结构
  18. C++ STL 教程
  19. 310实验室(六)CMake学习心得
  20. Node.js 部署到 CentOs

热门文章

  1. vuex的简单理解
  2. thinkphp5+layui多图片上传
  3. display:inline-block元素之间空隙的产生原因和解决办法
  4. MySQL8连接数据库
  5. java 返回输入中出现次数最多的字符串
  6. 国产芯片选型手册及厂商名录 版本V2019
  7. (转)linux下weblogic12c集群的安装部署
  8. Java 接口和内部类
  9. FCC 成都社区&#183;前端周刊 第 6 期
  10. Python之网路编程之进程池及回调函数