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