每天一道leetcode234-回文链表
考试结束,班级平均分只拿到了年级第二,班主任于是问道:大家都知道世界第一高峰珠穆朗玛峰,有人知道世界第二高峰是什么吗?正当班主任要继续发话,只听到角落默默想起来一个声音:”乔戈里峰”
前言
2018.11.6号打卡
明天的题目:https://leetcode-cn.com/problems/remove-linked-list-elements/
以后明天的题目提取公布一下哈,因为有些朋友想提前做一下~
题目
leetcode234-回文链表
中文链接:
https://leetcode-cn.com/problems/palindrome-linked-list/
英文链表:
https://leetcode.com/problems/palindrome-linked-list/
难度:easy
分类:链表
题目详述
请判断一个链表是否为回文链表。
示例 1:
输入: 1->2
输出: false
示例 2:
输入: 1->2->2->1
输出: true
题目详解
距离AC只差一个测试用例的错误思路
- 之前应该有看过关于回文链表的一种解法,就是对于链表的每个元素依次乘以1,2,3,4…求得一个和sum1;
- 然后就是把这个链表反转,反转链表正好昨天做过哈,直接把代码拿来用,得到反转后的链表;
- 然后对于这个反转后的链表,依次遍历然后对于每个元素依次乘以1,2,3,4…求得一个和sum2;
- 然后比较这个两个sum值,如果相等,那么就是回文链表
代码
1/**
2 * Definition for singly-linked list.
3 * public class ListNode {
4 * int val;
5 * ListNode next;
6 * ListNode(int x) { val = x; }
7 * }
8 */
9class Solution {
10 public boolean isPalindrome(ListNode head) {
11 int sum1 = 0;
12 if(head == null || head.next == null)
13 return true;
14 int count = 1;
15 ListNode temp = head;
16 while(temp != null)
17 {
18 sum1 += count * temp.val;
19 count += 1;
20 temp = temp.next;
21 }
22 int sum2 = 0;
23 count = 1;
24 head = reverseList(head);
25 temp = head;
26 while(temp != null)
27 {
28 sum2 += count * temp.val;
29 count += 1;
30 temp = temp.next;
31 }
32 if(sum1 == sum2)
33 return true;
34 return false;
35 }
36 public ListNode reverseList(ListNode head) {
37 if(head == null || head.next == null)
38 return head;
39 ListNode pre = head;
40 ListNode pNode = head.next;
41 ListNode next = head;
42 //首先处理前两个节点;
43 pre.next = null;
44 while(pNode != null)
45 {
46 next = pNode.next;
47 pNode.next = pre;
48 pre = pNode;
49 pNode = next;
50 }
51 return pre;
52 }
53}
结果,差一个用例没过,说明这种方法还是有点问题~~~~
dasda
正确的思路
- 由于题目说了时间复杂度是O(n),空间复杂度是O(1),所以不能使用新的空间;
- 思路还是反转链表,不过不是反转整个链表,反转的是后半部分的链表;
- 后半部分的链表反转完毕,然后一个从头开始遍历,一个从尾巴开始遍历,依次比较节点的值是不是一样,一样就继续往下,不一样直接就返回false.
代码
1/**
2 * Definition for singly-linked list.
3 * public class ListNode {
4 * int val;
5 * ListNode next;
6 * ListNode(int x) { val = x; }
7 * }
8 */
9class Solution {
10 public boolean isPalindrome(ListNode head) {
11 if(head == null || head.next == null)
12 return true;
13 int length = 0;
14 ListNode temp = head;
15 while(temp != null)
16 {
17 length++;
18 temp = temp.next;
19 }
20 int halfLength = length / 2;
21 temp = head;
22 for(int i=0;i<halfLength;i++)
23 temp = temp.next;
24 ListNode pre = temp;
25 ListNode pNode = temp.next;
26 ListNode next = pNode;
27 while(pNode != null)
28 {
29 next = pNode.next;
30 pNode.next = pre;
31 pre = pNode;
32 pNode = next;
33 }
34 for(int i=0;i<halfLength;i++)
35 {
36 if(head.val != pre.val)
37 return false;
38 head = head.next;
39 pre = pre.next;
40 }
41 return true;
42 }
43}
代码讲解
- 15到20行,遍历链表,求链表长度的一半的值
- 22-23行,找到链表的中间节点
- 24-33行反转链表
- 34-40行一个从头,一个从尾巴,依次比较值是否相等,不相等就返回false
- 最后就是返回true
结束语
2018.11.6号 打卡
作者乔戈里亲历2019秋招,哈工大计算机本硕,百度准入职java工程师,欢迎大家关注我的微信公众号:程序员乔戈里,公众号有3T编程资源,以及我和我朋友(准入职百度C++工程师)在秋招期间整理的近200M的面试必考的java与C++面经,并有每天一道leetcode打卡群与技术交流群,欢迎关注。
每天一道leetcode234-回文链表的更多相关文章
- leetcode234 回文链表 两种做法(stack(空间非O(1)),空间O(1))
link: leetcode234 回文链表 方法1, 快慢指针,把前半部分存入栈中和后半部分比较 public boolean isPalindrome(ListNode head) { if(he ...
- [Swift]LeetCode234. 回文链表 | Palindrome Linked List
Given a singly linked list, determine if it is a palindrome. Example 1: Input: 1->2 Output: false ...
- LeetCode234 回文链表
请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶:你能否用 O(n) 时间复杂 ...
- [LeetCode] Palindrome Linked List 回文链表
Given a singly linked list, determine if it is a palindrome. Follow up: Could you do it in O(n) time ...
- [CareerCup] 2.7 Palindrome Linked List 回文链表
2.7 Implement a function to check if a linked list is a palindrome. LeetCode上的原题,参见我之前的博客Palindrome ...
- lintcode 中等题:Palindrome Linked List 回文链表
题目 回文链表 设计一种方式检查一个链表是否为回文链表. 样例 1->2->1 就是一个回文链表. 挑战 O(n)的时间和O(1)的额外空间. 解题 法一: 再定义一个链表,存放链表反转的 ...
- Leetcode:234 回文链表
leetcode:234 回文链表 关键点:请判断一个链表是否为回文链表.示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true. ...
- 判断回文字符串、回文链表、回文数(python实现)
所谓回文字符串,就是正读和反读都一样的字符串,比如"level"或者"noon"等等就是回文串.即是对称结构 判断回文字符串 方法一: def is_palin ...
- 如何判断一个单向链表是否为回文链表(Palindrome Linked List)
题目:给定一个单向链表,判断它是不是回文链表(即从前往后读和从后往前读是一样的).原题见下图,还要求了O(n)的时间复杂度O(1)的空间复杂度. 我的思考: 1,一看到这个题目,大脑马上想到的解决方案 ...
- 【leetcode 简单】 第六十七题 回文链表
请判断一个链表是否为回文链表. 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶: 你能否用 O(n) 时间复 ...
随机推荐
- 正则表达式REGEXP
正则表达式:REGular EXPression, REGEXP 元字符: .: 匹配任意单个字符 []: 匹配指定范围内的任意单个字符 [^]:匹配指定范围外的任意单个字符 字符集合:[:digit ...
- c# BindingSource 类
1.引言 BindingSource组件是数据源和控件间的一座桥,同时提供了大量的API和Event供我们使用.使用这些API我们可以将Code与各种具体类型数据源进行解耦:使用这些Eve ...
- cesium编程入门(八)设置材质
cesium编程入门(八)设置材质 Cesium中为几何形状设置材质有多种方法 第一种方法 Material 直接构建Cesium.Material对象,通过设置Material的属性来进行控制,官方 ...
- WP8.1StoreApp(WP8.1RT)---添加推送功能和获取系统信息
添加推送通知 1:Package.appxmanifest中的声明添加后台任务的推送通知权限 2:var channel = await PushNotificationChannelManager. ...
- Application Loader上传app,一直卡在“正在通过 App Store 进行鉴定”
1.问题现象描述 上传iOS应用,卡在 Authenticating with the iTunes Store 2.解决办法 2.1 打开终端输入代码即可 cd ~ mv .itmstranspor ...
- “全栈2019”Java异常第十八章:Exception详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- 配置DNS服务器转发器
1.(windows server 2008 r2)控制面板->管理工具->服务器管理器->DNS->服务器图标->属性 2.转发器->编辑 3.填写DNS并点击确 ...
- 自适应大邻域搜索代码系列之(1) - 使用ALNS代码框架求解TSP问题
前言 上次出了邻域搜索的各种概念科普,尤其是LNS和ALNS的具体过程更是描述得一清二楚.不知道你萌都懂了吗?小编相信大家早就get到啦.不过有个别不愿意透露姓名的热心网友表示上次没有代码,遂不过瘾啊 ...
- AssertJ断言系列-----------<数据库断言二>
那么,在实际的接口测试中,我们除了要断言响应的数据正确之外,可能有的还需要断言数据层是否数据真的有入库. assertj db是可以直接对数据库进行断言和操作的. 一.创建一个students表 CR ...
- IDEA + SpringBoot + Java搭建Web项目
打开IDEA,选择Spring Initializr,默认配置,点击Next  添写GAV.(group.Artifact.Version)  选择Spring Boot版本,这里选2.1.4稳定 ...