zoukankan      html  css  js  c++  java
  • 每天一道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打卡群与技术交流群,欢迎关注。

  • 相关阅读:
    linux | 管道符、输出重定向
    php 升级php5.5 、php7
    mysql 启动失败
    centos7.2安装phpmyadmin
    php file_get_contents失败[function.file-get-contents]: failed to open stream: HTTP request failed!解决
    go println与printf区别
    前端 head 中mate 详解
    centos 7 安装mysql
    iOS数据持久化—数据库SQLite模糊查询
    C 语言字符串和格式化输入与输出
  • 原文地址:https://www.cnblogs.com/qiaogeli/p/9919702.html
Copyright © 2011-2022 走看看