LeetCode234_PalindromeLinkedList (推断是否为回文链表) Java题解
题目:
Given a singly linked list, determine if it is a palindrome.
Follow up:
Could you do it in O(n) time and O(1) space?
题解:
推断一个链表是不是回文的,这里要求O(n)时间复杂度和O(1)的空间时间复杂度。总共想了三种办法,三种办法都用到了两个指针,符合题目要求的仅仅有最后一种。
第一种办法:用数组倒着存前半段的链表的值。然后和后半段链表的值进行比較。
这样的解法执行的时间最久可能是由于数组倒着插入比較耗时。
代码:
- //用数组实现 o(n/2)空间
- public static boolean isPalindrome(ListNode head) {
- // ArrayList<Integer> nodeVal=new ArrayList<>();
- LinkedList<Integer> nodeVal=new LinkedList<>();
- if(head==null||head.next==null)
- return true;
- ListNode slow=head;
- ListNode fast=head;
- nodeVal.add(0,slow.val);
- while(fast.next!=null&&fast.next.next!=null)
- {
- fast=fast.next.next;
- slow=slow.next;
- nodeVal.add(0,slow.val);
- }
- ListNode cur=slow;
- if(fast.next!=null)//链表长度为偶数
- cur=slow.next;
- int i=0;
- while(cur!=null)
- {
- if(nodeVal.get(i)!=cur.val)
- return false;
- cur=cur.next;
- i++;
- }
- return true;
- }
另外一种解法:在第一种的思路的基础上。我们要实现一个倒序,我们干嘛不用现成的数据结构-栈。于是把链表前半段压栈,然后出栈和后面的链表依次比較,这样的执行时间最短。但由于用到了栈还是不符合题目要求。
代码:
- //用栈实现
- public static boolean isPalindrome2(ListNode head) {
- Stack<ListNode> stack=new Stack<>();
- ListNode slow=head;
- ListNode fast=head;
- if(fast==null||fast.next==null)//0个节点或是1个节点
- return true;
- stack.push(slow);
- while(fast.next!=null&&fast.next.next!=null)
- {
- fast=fast.next.next;
- slow=slow.next;
- stack.push(slow);
- }
- if(fast.next!=null)//链表长度为偶数
- slow=slow.next;
- ListNode cur=slow;
- while(cur!=null)
- {
- if(cur.val!=stack.pop().val)
- return false;
- cur=cur.next;
- }
- return true;
- }
第三种:我们这样想,我们可不能够不借助外在的存储实现倒序呢,事实上是能够的,链表反转的时候我们就没有借助外在存储。
思路是把后半段的原地链表反转然后和前半段进行比較(当然你也能够反转前半段)执行时间略微比另外一种慢一些。可是符合题目O(1)空间复杂度的要求
代码:
- //链表原地转置实现o(1)空间复杂度
- public static boolean isPalindrome3(ListNode head) {
- ListNode slow=head;
- ListNode fast=head;
- if(fast==null||fast.next==null)//0个节点或是1个节点
- return true;
- while(fast.next!=null&&fast.next.next!=null)
- {
- fast=fast.next.next;
- slow=slow.next;
- }
- //对链表后半段进行反转
- ListNode midNode=slow;
- ListNode firNode=slow.next;//后半段链表的第一个节点
- ListNode cur=firNode.next;//插入节点从第一个节点后面一个開始
- firNode.next=null;//第一个节点最后会变最后一个节点
- while(cur!=null)
- {
- ListNode nextNode=cur.next;//保存下次遍历的节点
- cur.next=midNode.next;
- midNode.next=cur;
- cur=nextNode;
- }
- //反转之后对前后半段进行比較
- slow=head;
- fast=midNode.next;
- while(fast!=null)
- {
- if(fast.val!=slow.val)
- return false;
- slow=slow.next;
- fast=fast.next;
- }
- return true;
- }
LeetCode234_PalindromeLinkedList (推断是否为回文链表) Java题解的更多相关文章
- 领扣(LeetCode)回文链表 个人题解
请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶:你能否用 O(n) 时间复杂 ...
- Java判断链表是否为回文链表
请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 思路:1.通过快慢指针,来遍历链表 ...
- Java实现 LeetCode 234 回文链表
234. 回文链表 请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶: 你能否 ...
- lintcode 中等题:Palindrome Linked List 回文链表
题目 回文链表 设计一种方式检查一个链表是否为回文链表. 样例 1->2->1 就是一个回文链表. 挑战 O(n)的时间和O(1)的额外空间. 解题 法一: 再定义一个链表,存放链表反转的 ...
- LeetCode OJ:Palindrome Linked List(回文链表判断)
Given a singly linked list, determine if it is a palindrome. Follow up:Could you do it in O(n) time ...
- 234 Palindrome Linked List 回文链表
请检查一个链表是否为回文链表. 进阶:你能在 O(n) 的时间和 O(1) 的额外空间中做到吗? 详见:https://leetcode.com/problems/palindrome-linked- ...
- [LC]234题 Linked List Cycle (回文链表)(链表)
①中文题目 请判断一个链表是否为回文链表. 示例 1: 输入: 1->2输出: false示例 2: 输入: 1->2->2->1输出: true进阶:你能否用 O(n) 时间 ...
- LeetCode 234:回文链表 Palindrome Linked List
请判断一个链表是否为回文链表. Given a singly linked list, determine if it is a palindrome. 示例 1: 输入: 1->2 输出: ...
- leetcode面试题 02.06. 回文链表,解题心路
目录 leetcode面试题 02.06. 回文链表,解题心路 1.题目描述 2.java语言题解一 3.java语言题解二 4.C语言题解一 leetcode面试题 02.06. 回文链表,解题心路 ...
随机推荐
- mysql若干问题
一.Host ip is not allowed to connect to this MySql server 解决方法:这是因为你的账号不允许远程登录,只能在localhost.只要在localh ...
- 实用and常用shell命令汇编
很久没写blog了,基本都在用 github和笔记.现在将一些常用的shell并且很使用的shell用法分享一下: 分行读取,切割,计数: cat product.txt | while read l ...
- FCC 基础JavaScript 练习2
1. 引号不是字符串中唯一的可以被转义字符.下面是常见的转义序列列表: \' 单引号 \" 双引号 \\ 反斜杠符 \n 换行符 \r 回车符 \t 制表符 \b 退格符 \f 换页符 ...
- JavaScript(七)数组
Array类型 1.创建数组 字面量 var arr = [];//不要在低版本的浏览其中创建字面量的时候最后 //一个item后面加 逗号 低版本会 再新建一个空的item 构造函数 var arr ...
- Android开发笔记(4)——MainActivity.java文件修改&布局嵌套
笔记链接:http://www.cnblogs.com/igoslly/p/6805020.html 笔记以开发名为CoffeeOrder的app活动为线索,介绍app如何从功能设计→ ...
- interface与抽象类
抽象类: 定义:在 class 前加了 abstract 关键字且存在抽象方法(在类方法 function 关键字前加了 abstract 关键字)的类 抽象类不能被实例化. 抽象类被继承之后,子类必 ...
- HDU_3732_(多重背包)
Ahui Writes Word Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU_1556_线段树区间更新
Color the ball Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- Context Switches msdn
Context Switches https://msdn.microsoft.com/en-us/library/ms682105(VS.85).aspx The scheduler mainta ...
- jmeter接口测试小结
摘自:http://www.cnblogs.com/houzhizhe/p/6839736.html JMeter做http接口压力测试 测前准备 用JMeter做接口的压测非常方便,在压测之前我们需 ...