zoukankan      html  css  js  c++  java
  • 输出链表中倒数第k个节点

    题目描述

    输入一个链表,输出该链表中倒数第k个结点。
    struct ListNode {
        int val;
        struct ListNode *next;
        ListNode(int x) :
                val(x), next(NULL) {
        }
    };


    算法的实现:快慢指针

        ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
            if(pListHead==NULL||k==0) return NULL;
            ListNode *fast=NULL;
            fast=pListHead;
            ListNode *slow=NULL;
            slow=pListHead;
           for(int i=1;i<k;i++)//注意此处PListHeaD是头结点,需要移动K-1个,之间相差K
               if(fast->next!=NULL)//注意此处快指针的next存在和不存在的情况
                 fast=fast->next;
               else
                   return NULL;
            while(fast->next!=NULL)
            {
                fast=fast->next;
                slow=slow->next;
            }
            return slow;        
        }
  • 相关阅读:
    代码查错1
    代码查错
    垃圾回收器
    面试题(操作语句)
    面试题(JVM加载机制)
    面试题(线程)
    异常
    IO流
    es5 学习笔记
    ECMAScript5 Object的新属性方法
  • 原文地址:https://www.cnblogs.com/wft1990/p/7436624.html
Copyright © 2011-2022 走看看