码迷,mamicode.com
首页 > 其他好文 > 详细

[剑指offer] 链表中倒数第k个结点

时间:2016-05-04 10:41:14      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:

题目描述

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

输入描述

链表

输出描述

倒数第k个结点

题目分析

节点描述:

public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}

解法一 运行时间:35ms 占用内存:503k

public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {
           if(head==null || k<=0){
               return null;
           }        
           ListNode last = head;
           for(int i=1;i<k;i++){
               last = last.next;
               if(last==null){
                   return null;
               }
           }

           while(last.next!=null){
               head = head.next;
               last = last.next;
           }

           return head;
    }
}

  ①首先判断边界,新建一个节点last,开始指向head节点; 
  
  ②向后遍历K-1次使它与head节点相差k个节点(如果链表长度小于k就返回null);  
  
  ③两个节点同时向后遍历,直到last指向最后一个节点为止。

  ④返回现在的head节点就是倒数第k个节点。

解法二  运行时间:34ms 占用内存:629k

public class Solution {
    public ListNode FindKthToTail(ListNode head,int k) {
     if(head==null || k<=0){
               return null;
        }

        ListNode p = head;
        ListNode q = head;
        int i = 0;
        for (; p != null; i++) {
            if (i >= k){
                q = q.next;
            }     
            p = p.next;
        }
        return i < k ? null : q;
    }
}

  与解法一是同一种思路,不过只进行一次遍历,事件复杂度O(n)。

[剑指offer] 链表中倒数第k个结点

标签:

原文地址:http://blog.csdn.net/amazing7/article/details/51312721

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!