回文链表 牛客网 程序员面试金典  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. Azure 实践(4)- CI/CD .netcore项目Docker构建及部署

    上篇已介绍了.netcore项目构建的相关步骤,本篇继续完善 1.什么是CI/CD CI/CD 中的"CI"始终指持续集成,它属于开发人员的自动化流程.成功的 CI 意味着应用代码 ...

  2. 328 day07线程池、Lambda表达式

    day07[线程池.Lambda表达式] 主要内容 等待与唤醒案例 线程池 Lambda表达式 教学目标 -[ ] 能够理解线程通信概念 -[ ] 能够理解等待唤醒机制 -[ ] 能够描述Java中线 ...

  3. 用Python实现童年的21款小游戏,有你玩过的吗?(不要错过哦)

    Python为什么能这么火热,Python相对于其他语言来说比较简单,即使是零基础的普通人也能很快的掌握,在其他方面比如,处于灰色界的爬虫,要VIP的视频,小说,歌,没有爬虫解决不了的:数据挖掘及分析 ...

  4. trait能力在PHP中的使用

    相信大家对trait已经不陌生了,早在5.4时,trait就已经出现在了PHP的新特性中.当然,本身trait也是特性的意思,但这个特性的主要能力就是为了代码的复用. 我们都知道,PHP是现代化的面向 ...

  5. 浏览器缓存旧的js文件或css文件导致没出现预期效果

    最好在加载的js或css文件后加上 ?v=1.0.0 版本号,更新js后就更改一下版本号即可

  6. 教你用ps如何将图片、文字做出模糊斑驳的作旧效果

    1.对图片的图层执行滤镜-风格化-扩散,选变亮优先. 2.选择画笔工具,在画笔选项里选择喷溅59像素,画笔大小我用的是100px,大家可以根据自己的情况自定义大小,前景设置为黑色. 3.在图章图层上方 ...

  7. Java基础系列(13)- 包机制

    包机制 为了更好的组织类,Java提供了包机制,用于区别类名的命名空间 包语句的语法格式为: package pkg1[. pkg2[. pkg3...]]; 一般利用公司域名倒置作为报名 为了能够使 ...

  8. K8s一键安装

    安装案例: 系统:Centos可以多台Master(Master不能低于3台)多台Node此案例使用三台Master两台Node,用户名root,密码均为123456 master 192.168.2 ...

  9. 51nod1667-概率好题【容斥,组合数学】

    正题 题目链接:http://www.51nod.com/Challenge/Problem.html#problemId=1667 题目大意 两个人. 第一个人有\(k_1\)个集合,第\(i\)个 ...

  10. scheduler源码分析——调度流程

    前言 当api-server处理完一个pod的创建请求后,此时可以通过kubectl把pod get出来,但是pod的状态是Pending.在这个Pod能运行在节点上之前,它还需要经过schedule ...