博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
面试题15 :链表中倒数第k个结点
阅读量:3699 次
发布时间:2019-05-21

本文共 2618 字,大约阅读时间需要 8 分钟。

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


解题思路:

为了实现只遍历链表一次就能找到倒数第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大于0        if (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)); }}

转载地址:http://szicn.baihongyu.com/

你可能感兴趣的文章
swagger配置及升级版swagger-bootstrap-ui配置+访问账号密码登录限制
查看>>
网易云Api,轻松获取音乐数据
查看>>
Spring boot 注解@Async无效,不起作用
查看>>
List与String相互转换
查看>>
阿里巴巴fastjson api使用教程
查看>>
栈与堆的个人理解
查看>>
Lambda表达式概念理解
查看>>
Java 8 Stream 优雅的流式编程, 过滤集合类型的数据lambda表达式
查看>>
浅谈重不重写equals和hashcode对于HashMap添加元素的影响
查看>>
面试题:Redis是单线程,速度为什么会这么快?
查看>>
关于String==和String.intern()的面试题,一文读懂
查看>>
new Hashmap 和 new ArrayList时设置初始化容量多少合适
查看>>
java面试中面试官让你讲讲反射,应该从何讲起?
查看>>
RocketMQ概念简介
查看>>
关于BIO和NIO的理解与总结(网络IO)
查看>>
STL应用之stack、queue、priority_queue容器适配器
查看>>
继承的学习——C++
查看>>
实现一个minishell小程序
查看>>
设计模式(单例模式)——Linux系统编程
查看>>
网络基础1(协议、协议模型、IP、Port、网络字节序)——Linux网络编程
查看>>