gpt4 book ai didi

Java输出链表倒数第k个节点

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 31 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Java输出链表倒数第k个节点由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

问题描述 。

输入一个链表,输出该链表中倒数第k个结点。(尾结点是倒数第一个) 。

结点定义如下:

?
1
2
3
4
5
6
7
8
public class ListNode {
   int val;
   ListNode next = null ;
 
   ListNode( int val) {
     this.val = val;
   }
}

思路1:

先遍历链表,计算其长度length; 然后计算出倒数第k个结点就是正数第length - k + 1. 最后再遍历链表,找到所求结点 时间复杂度O(2n),需要遍历两次链表 。

代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public ListNode FindKthToTail(ListNode head, int k) {
     if (head == null || k <= 0 ){
       return null ;
     }
     //直接遍历
     ListNode p = head;
     int length = 1 ;
     while (p.next != null ){
       length++;
       p = p.next;
     }
     int index = length - k + 1 ;
     if (index <= 0 ){
       return null ;
     }
     p = head;
     int num = 1 ;
     while (p.next != null && num < index){
       num++;
       p = p.next;
     }
     if (num < index){
       return null ;
     } else {
       return p;
     }
   }

思路2:

期待只遍历链表一次就能得到。 设置两个指针,一个初始化指向第一个结点,第二个指向第k个结点。然后两个指针同步向后移动,当第二个指向尾结点时,第一个指针即指向了倒数第k个结点 。

代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public ListNode FindKthToTail(ListNode head, int k) {
     if (head == null || k <= 0 ){
       return null ;
     }
     //直接遍历
     ListNode p = head;
     ListNode q = head;
     for ( int i = 0 ; i < k- 1 ; i++){
       if (q == null ){
         return null ;
       }
       q = q.next;
     }
     if (q == null ){
       return null ;
     }
     while (q.next != null ){
       p = p.next;
       q = q.next;
     }
     return p;
   }

思路3:

将链表反转,那么原问题就变为求正数第k个结点。 然而这改变了原本的链表,且并不会比思路2更高效 。

链表反转:参考《Java语言实现反转链表代码示例》 。

总结 。

以上就是本文关于Java输出链表倒数第k个节点的全部内容,如有不足之处,欢迎留言指出,小编一定及时更正,给大家更好的阅读体验和帮助,感谢朋友们对本站的支持! 。

原文链接:http://blog.csdn.net/lilianforever/article/details/51839755 。

最后此篇关于Java输出链表倒数第k个节点的文章就讲到这里了,如果你想了解更多关于Java输出链表倒数第k个节点的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com