`

链表倒数第n个节点

阅读更多

题意:

找到单链表倒数第n个节点,保证链表中节点的最少数量为n。

 

解法:我们看到这个问题首先要考虑的就是边界情况,指针是否为空?n是否为0?n是否 大于链表的长度?

          边界定义好,我们就开始写代码了,定义两个指针,第一个指针走到n的时候,第二个指针开始行走,当第一个指针走到指针尾部的时候,返回第二个指针所指向的节点。

 

题目地址

 

代码如下:

/**
 * Definition for ListNode.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int val) {
 *         this.val = val;
 *         this.next = null;
 *     }
 * }
 */


public class Solution {
    /*
     * @param head: The first node of linked list.
     * @param n: An integer
     * @return: Nth to last node of a singly linked list. 
     */
    public ListNode nthToLast(ListNode head, int n) {
        // write your code here
        if(head == null||n==0){
            return null;
        }
        ListNode node1 = head;
        for(int i = 0 ; i < n-1 ; i++){
            if(node1.next!=null){
                node1 = node1.next;
            }else{
                return null;
            }
        }
        ListNode node2 = head;
        while(node1.next!=null){
            node1 = node1.next;
            node2 = node2.next;
        }
        return node2;
    }
}

 

分享到:
评论

相关推荐

    一次遍历找链表倒数第n个节点

    ### 一次遍历找链表倒数第n个节点 在计算机科学中,链表是一种常用的数据结构,它由一系列节点组成,每个节点包含数据和指向下一个节点的指针。有时候我们需要找到链表中的特定节点,例如倒数第n个节点。本篇文章将...

    删除链表中倒数第N个结点

    在这个问题中,我们需要处理一个特殊的链表操作,即“删除链表中倒数第N个节点”。这个任务在C++编程中尤为常见,因为它涉及到基本的指针操作和算法设计。 链表由一系列节点组成,每个节点包含数据和指向下一个节点...

    仅遍历一次得到链表的倒数第n个结点

    当我们谈论“倒数第n个结点”时,这意味着在链表的末尾开始计数,向前数到第n个节点。例如,如果链表有10个节点,倒数第3个节点实际上是第7个节点。这个问题的关键在于如何高效地找到这个节点,而无需进行多次遍历或...

    python 删除链表中倒数第N个节点(csdn)————程序.pdf

    而在特定的应用场景下,删除链表中倒数第N个节点的需求则更为特殊,它需要对链表的长度进行推算或利用指针巧妙地定位。 ### 解题思路一 此方法采用的空间换时间策略。首先,对原始链表进行一次遍历,目的是计算...

    查找链表中倒数第K个节点

    查找链表中倒数第K个节点,源代码验证通过,两种查找方法。

    js代码-5.1 删除链表倒数第n个节点 快慢指针

    删除链表中的特定节点是一项常见的操作,特别是倒数第n个节点。在这个问题中,我们将使用快慢指针(又称龟兔赛跑算法)来解决这个问题。这是一种高效且简洁的方法,尤其适用于单链表。 首先,让我们理解什么是快慢...

    LeetCode 删除链表的倒数第 N 个节点

    给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。 示例: 给定一个链表: 1-&gt;2-&gt;3-&gt;4-&gt;5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 1-&gt;2-&gt;3-&gt;5. 说明: 给定的 n 保证是有效的。 进阶: 你能...

    删除链表的倒数第 N 个结点(链表+栈)1

    给定一个单链表的头结点 `head` 和一个整数 `n`,我们需要找到链表的倒数第 N 个节点并将其删除,同时返回修改后的链表头结点。题目中还提到了进阶要求,即尝试使用一次遍历来实现。 首先,我们来看链表的定义。在 ...

    找出链表倒数第n个节点元素的二个方法

    在处理链表时,有时我们需要找到链表中的特定位置的节点,比如倒数第n个节点。本文介绍了两种不同的方法来实现这个目标,这两种方法都是针对单向链表的。 方法一:利用两个指针 这种方法的核心思想是使用两个指针p...

    2009计算机考研题:查找链表中倒数第k个结点

    本题目的核心是查找链表中的倒数第k个节点,这是一个经典的链表问题,常见于面试和考研试题中。下面我们将深入探讨这个问题以及如何通过编程解决。 首先,链表是由一系列节点组成的数据结构,每个节点包含一个数据...

    java-leetcode题解之第19题删除链表的倒数第N个结点.zip

    本题解集中于LeetCode的第19题,即“删除链表的倒数第N个节点”。这道题目主要涉及链表操作,特别是涉及到链表的遍历和节点删除,是链表数据结构的基础应用之一。 首先,我们需要理解链表的基本概念。链表是一种...

    数据结构 链表 查找倒数第N个节点的值 查找中间节点的值

    ### 数据结构:链表——查找倒数第N个节点与中间节点 #### 一、基础知识回顾 在深入了解本文档中的代码之前,我们首先简要回顾一下链表的基础知识。 **链表**是一种线性表的数据结构,其特点是通过指针连接各个...

    19删除链表的倒数第 N 个结点.zip

    19删除链表的倒数第 N 个结点.zip

    Veal98#CS-Wiki#19-删除链表的倒数第N个节点1

    19. 删除链表的倒数第N个节点19. 删除链表的倒数第N个节点 — Medium题目描述给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。示例

    c语言-c语言编程基础之leetcode题解第19题删除链表的倒数第N个结点.zip

    本主题将深入探讨如何利用C语言解决LeetCode中的第19题——删除链表的倒数第N个节点。这道题目要求我们在单向链表中找到倒数第N个节点并将其删除,而不需要预先知道链表的长度。 首先,我们需要理解链表的基本操作...

    删除链表的倒数第 N 个结点.md

    删除链表的倒数第 N 个结点.md

    c++-c++编程基础之leetcode题解第19题删除链表的倒数第N个结点.zip

    第19题,即“删除链表的倒数第N个节点”,是链表类问题中一个经典题目,旨在考察程序员对链表操作的理解以及如何在不遍历整个链表的情况下找到目标节点。 链表是一种数据结构,它由一系列节点组成,每个节点包含...

    java面试-leetcode面试题解之第19题删除链表的倒数第N个结点.zip

    第19题,删除链表的倒数第N个节点,是一个典型的链表操作问题,对于求职者来说,掌握这类问题的解决方案至关重要。这道题目旨在考察候选人对链表的基本操作、指针技巧以及对数据结构的理解。 首先,我们需要了解...

    C#-Leetcode编程题解之第19题删除链表的倒数第N个结点.zip

    在本压缩包中,我们关注的是C#编程语言在解决LeetCode算法问题中的应用,特别是第19题——"删除链表的倒数第N个节点"。这是一道典型的链表操作题目,旨在考察程序员对链表结构的理解以及如何在单链表中进行高效的...

Global site tag (gtag.js) - Google Analytics