剑指Offer—编程题15(链表中倒数第k个结点)

2024-06-24 08:32

本文主要是介绍剑指Offer—编程题15(链表中倒数第k个结点),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:输入一个链表,输出该链表中倒数第k 个结点.为了符合大多数人的习惯,本题从1 开始计数,即链表的尾结点是倒数第1 个结点.例如一个链表有6 个结点,从头结点开始它们的值依次是1 、2、3、4、5 、6。这个个链表的倒数第3 个结点是值为4 的结点.

public static class ListNode {int value;ListNode next;
}

解题思路:

为了实现只遍历链表一次就能找到倒数第k 个结点,我们可以定义两 
个指针。第一个指针从链表的头指针开始遍历向前走k-1步,第二个指针保持不动;从第k 步开始,第二个指针也开始从链表的头指针开始遍历。由于两个指针的距离保持在k-1 , 当第一个(走在前面的)指针到达链表的尾结点时,第二个指针(走在后面的)指针正好是倒数第k 个结点。

代码实现:

public class Test15 {public static class ListNode {int value;ListNode next;}/*** 输入一个键表,输出该链表中倒数第k 个结点.为了符合大多数人的习惯,* 本题从1开始计数,即链表的尾结点是倒数第1个结点.例如一个链表有6个结点,* 从头结点开始它们的值依次是1、2、3、4、5 6。这个链表的倒数第3个结点是值为4的结点.** @param head 链表的头结点* @param k    倒数第k个结点* @return 倒数第k个结点*/public static ListNode findKthToTail(ListNode head, int k) {// 输入的链表不能为空,并且k大于0if (k < 1 || head == null) {return null;}// 指向头结点ListNode pointer = head;// 倒数第k个结点与倒数第一个结点相隔k-1个位置// pointer先走k-1个位置for (int i = 1; i < k; i++) {// 说明还有结点if (pointer.next != null) {pointer = pointer.next;}// 已经没有节点了,但是i还没有到达k-1说明k太大,链表中没有那么多的元素else {// 返回结果return null;}}// pointer还没有走到链表的末尾,那么pointer和head一起走,// 当pointer走到最后一个结点即,pointer.next=null时,head就是倒数第k个结点while (pointer.next != null) {head = head.next;pointer = pointer.next;}// 返回结果return head;}public static void main(String[] args) {ListNode head = new ListNode();head.value = 1;head.next = new ListNode();head.next.value = 2;head.next.next = new ListNode();head.next.next.value = 3;head.next.next.next = new ListNode();head.next.next.next.value = 4;head.next.next.next.next = new ListNode();head.next.next.next.next.value = 5;head.next.next.next.next.next = new ListNode();head.next.next.next.next.next.value = 6;head.next.next.next.next.next.next = new ListNode();head.next.next.next.next.next.next.value = 7;head.next.next.next.next.next.next.next = new ListNode();head.next.next.next.next.next.next.next.value = 8;head.next.next.next.next.next.next.next.next = new ListNode();head.next.next.next.next.next.next.next.next.value = 9;System.out.println(findKthToTail(head, 1).value); // 倒数第一个System.out.println(findKthToTail(head, 5).value); // 中间的一个System.out.println(findKthToTail(head, 9).value); // 倒数最后一个就是顺数第一个System.out.println(findKthToTail(head, 10));}
}


这里写图片描述

这篇关于剑指Offer—编程题15(链表中倒数第k个结点)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089636

相关文章

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后