回文链表 牛客网 程序员面试金典  C++ Python

  • 题目描述
  • 请编写一个函数,检查链表是否为回文。
  • 给定一个链表ListNode* pHead,请返回一个bool,代表链表是否为回文。
  • 测试样例:
  • {1,2,3,2,1}
  • 返回:true
  • {1,2,3,2,3}
  • 返回:false
class Palindrome {
public:
// run:4ms memory:492k
bool isPalindrome(ListNode* pHead) {
if(NULL == pHead) return true;
if(NULL == pHead->next) return true;
if(NULL == pHead->next->next)
if(pHead->val == pHead->next->val) return true;
else return false;
bool ret = true;
ListNode* lastNode = NULL;
ListNode* nextNode = pHead->next;
ListNode* pSlow = pHead;
ListNode* pFast = pHead;
while(pFast && pFast->next){
pFast = pFast->next->next;
pSlow->next = lastNode;
lastNode = pSlow;
pSlow = nextNode;
nextNode = nextNode->next;
}
ListNode* lNode = lastNode;
ListNode* nNode = pSlow;
if (NULL == pFast)
if (pSlow->val != lastNode->val) ret = false;
else lastNode = lastNode->next;
while(lastNode){
if (lastNode->val != nextNode->val) {
ret = false;
break;
} lastNode = lastNode->next;
nextNode = nextNode->next;
}
while(lNode){
ListNode* tmp = lNode->next;
lNode->next = nNode;
nNode = lNode;
lNode = tmp;
}
return ret;
} // run:5ms memory:600k
bool isPalindrome2(ListNode* pHead) {
if(NULL == pHead) return true;
if(NULL == pHead->next) return true;
if(NULL == pHead->next->next)
if(pHead->val == pHead->next->val) return true;
else return false;
ListNode* lastNode = NULL;
ListNode* nextNode = pHead->next;
ListNode* pSlow = pHead;
ListNode* pFast = pHead;
while(pFast && pFast->next){
pFast = pFast->next->next;
pSlow->next = lastNode;
lastNode = pSlow;
pSlow = nextNode;
nextNode = nextNode->next;
}
if (NULL == pFast)
if (pSlow->val != lastNode->val) return false;
else lastNode = lastNode->next;
while(lastNode){
if (lastNode->val != nextNode->val) return false;
lastNode = lastNode->next;
nextNode = nextNode->next;
}
return true;
} // run:4ms memory:476k
bool isPalindrome3(ListNode* pHead) {
if(NULL == pHead) return true;
if(NULL == pHead->next) return true;
if(NULL == pHead->next->next)
if(pHead->val == pHead->next->val)
return true;
else return false;
ListNode* lastNode = NULL;
ListNode* nextNode = pHead->next;
ListNode* pSlow = pHead;
ListNode* pFast = pHead;
while(pFast && pFast->next){
pFast = pFast->next->next;
pSlow->next = lastNode;
lastNode = pSlow;
pSlow = nextNode;
nextNode = nextNode->next;
}
if (NULL == pFast){
if (pSlow->val != lastNode->val)
return false;
else{
lastNode = lastNode->next;
while(lastNode){
if (lastNode->val != nextNode->val)
return false;
lastNode = lastNode->next;
nextNode = nextNode->next;
}
}
}
if(NULL == pFast->next){
while(lastNode){
if (lastNode->val != nextNode->val)
return false;
lastNode = lastNode->next;
nextNode = nextNode->next;
}
}
return true;
}
};

Python

# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None class Palindrome:
# run:43ms memory:5732k
def isPalindrome(self, pHead):
if None == pHead: return True
if None == pHead.next: return True
if None == pHead.next.next:
if pHead.val == pHead.next.val: return True
else: return False
ret = True
lastNode = None
nextNode = pHead
pFast = pHead
pSlow = pHead
while pFast and pFast.next:
pFast = pFast.next.next
nextNode = pSlow.next
pSlow.next = lastNode
lastNode = pSlow
pSlow = nextNode
nextNode = nextNode.next
lNode = lastNode
nNode = pSlow
if None == pFast:
if pSlow.val != lastNode.val:ret = False
else:lastNode = lastNode.next
while lastNode and nextNode:
if lastNode.val != nextNode.val:
ret = False
lastNode = lastNode.next
nextNode = nextNode.next
while lNode:
tmp = lNode.next
lNode.next = nNode
nNode = lNode
lNode = tmp
return ret # run:34ms memory:5728k
def isPalindrome2(self, pHead):
if None == pHead: return True
if None == pHead.next: return True
if None == pHead.next.next:
if pHead.val == pHead.next.val: return True
else: return False
lastNode = None
nextNode = pHead
pFast = pHead
pSlow = pHead
while pFast and pFast.next:
pFast = pFast.next.next
nextNode = pSlow.next
pSlow.next = lastNode
lastNode = pSlow
pSlow = nextNode
nextNode = nextNode.next
if None == pFast:
if pSlow.val != lastNode.val:return False
else:lastNode = lastNode.next
while lastNode:
if lastNode.val != nextNode.val:return False
lastNode = lastNode.next
nextNode = nextNode.next
return True

回文链表 牛客网 程序员面试金典 C++ Python的更多相关文章

  1. 链表分割 牛客网 程序员面试金典 C++ Python

    链表分割 牛客网 程序员面试金典 C++ Python 题目描述 编写代码,以给定值x为基准将链表分割成两部分,所有小于x的结点排在大于或等于x的结点之前 给定一个链表的头指针 ListNode* p ...

  2. 链表中倒数第K个结点 牛客网 程序员面试金典 C++ Python

    链表中倒数第K个结点 牛客网 程序员面试金典 C++ Python 题目描述 输入一个链表,输出该链表中倒数第k个结点. C++ /* struct ListNode { int val; struc ...

  3. 链式A+B 牛客网 程序员面试金典 C++ Python

    链式A+B 牛客网 程序员面试金典 C++ Python 题目描述 有两个用链表表示的整数,每个结点包含一个数位.这些数位是反向存放的,也就是个位排在链表的首部.编写函数对这两个整数求和,并用链表形式 ...

  4. 输出单层结点 牛客网 程序员面试金典 C++ Python

    输出单层结点 牛客网 程序员面试金典 C++ Python 题目描述 对于一棵二叉树,请设计一个算法,创建含有某一深度上所有结点的链表. 给定二叉树的根结点指针TreeNode* root,以及链表上 ...

  5. 访问单个结点的删除 牛客网 程序员面试金典 C++ Python

    访问单个结点的删除 牛客网 程序员面试金典 C++ Python 题目描述 实现一个算法,删除单向链表中间的某个结点,假定你只能访问该结点. 给定待删除的节点,请执行删除操作,若该节点为尾节点,返回f ...

  6. 平分的直线 牛客网 程序员面试金典 C++ Python

    平分的直线 牛客网 程序员面试金典 C++ Python 题目描述 在二维平面上,有两个正方形,请找出一条直线,能够将这两个正方形对半分.假定正方形的上下两条边与x轴平行. 给定两个vecotrA和B ...

  7. 奇偶位交换 牛客网 程序员面试金典 C++ Python

    奇偶位交换 牛客网 程序员面试金典 C++ Python 题目描述 请编写程序交换一个数的二进制的奇数位和偶数位.(使用越少的指令越好) 给定一个int x,请返回交换后的数int. 测试样例: 10 ...

  8. 字符串压缩 牛客网 程序员面试金典 C++ Python

    字符串压缩 牛客网 程序员面试金典 C++ Python 题目描述 利用字符重复出现的次数,编写一个方法,实现基本的字符串压缩功能.比如,字符串"aabcccccaaa"经压缩会变 ...

  9. 双栈排序 牛客网 程序员面试金典 C++ Python

    双栈排序 牛客网 程序员面试金典 C++ Python 题目描述 请编写一个程序,按升序对栈进行排序(即最大元素位于栈顶),要求最多只能使用一个额外的栈存放临时数据,但不得将元素复制到别的数据结构中. ...

随机推荐

  1. 为什么在匿名内部类中引用外部对象要加final修饰符

    当所在的方法的形参需要被内部类里面使用时,该形参必须为final. 为什么必须要为final呢? 首先我们知道在内部类编译成功后,它会产生一个class文件,该class文件与外部类并不是同一clas ...

  2. npm WARN ajv-keywords@2.1.1 requires a peer of ajv@^5.0.0 but none is installed. You must install peer dependencies yourself.

    解决: npm install -g npm-install-peers npm install -g npm npm i ajv 但是好像没啥用

  3. 【PHP】随机生成名字

    public function test(){ $a = "赵 钱 孙 李 周 吴 郑 王 冯 陈 楮 卫 蒋 沈 韩 杨 朱 秦 尤 许 何 吕 施 张 孔 曹 严 华 金 魏 陶 姜 戚 ...

  4. 一文让你掌握软件测试工程师SQL面试题

    数据结构说明 已知有如下4张表: 学生表:student(学号,学生姓名,出生年月,性别) 成绩表:score(学号,课程号,成绩) 课程表:course(课程号,课程名称,教师号) 教师表:teac ...

  5. Oracle基本入门

    一.数据的存储 1.java 程序中的对象:数组.集合保存.当运行的程序结束的时候,里面的数据就消亡. 2.文件存储系统: 存在的缺陷: 2.1)没有明确的数据类型划分. 2.2)没有用户身份验证机制 ...

  6. english note [6.3to6.9]

    6.3 http://www.51voa.com/VOA_Special_English/pakistan-town-struggles-with-rise-in-hiv-infections-821 ...

  7. 鸿蒙内核源码分析(内存分配篇) | 内存有哪些分配方式  | 百篇博客分析OpenHarmony源码 | v11.02

    百篇博客系列篇.本篇为: v11.xx 鸿蒙内核源码分析(内存分配篇) | 内存有哪些分配方式 | 51.c.h .o 内存管理相关篇为: v11.xx 鸿蒙内核源码分析(内存分配篇) | 内存有哪些 ...

  8. P5956-[POI2017]Podzielno【数学】

    正题 题目链接:https://www.luogu.com.cn/problem/P5956 题目大意 \(B\)进制下,给出序列\(a\),\(a_i\)表示数字\(i\)有多少个.求一个最大的\( ...

  9. 面试必问:Java 垃圾回收机制

    摘要:垃圾回收机制是守护线程的最佳示例,因为它始终在后台运行. 本文分享自华为云社区<一文带你了解Java 中的垃圾回收机制>,作者:海拥. 介绍 在 C/C++ 中,程序员负责对象的创建 ...

  10. 前端规范之CSS规范(Stylelint)

    代码规范是软件开发领域经久不衰的话题,几乎所有工程师在开发过程中都会遇到或思考过这一问题.而随着前端应用的大型化和复杂化,越来越多的前端团队也开始重视代码规范.同样,前段时间,笔者所在的团队也开展了一 ...