首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何从单链表的末尾找到第n个元素?

如何从单链表的末尾找到第n个元素?
EN

Stack Overflow用户
提问于 2010-04-08 16:03:57
回答 29查看 99.5K关注 0票数 65

下面的函数尝试查找nth to 单链表的最后一个元素。

例如:

如果元素为8->10->5->7->2->1->5->4->10->10,则结果为7th to last node is 7

有没有人能帮我讲讲这段代码是如何工作的,或者有没有更好更简单的方法?

代码语言:javascript
运行
复制
LinkedListNode nthToLast(LinkedListNode head, int n) {
  if (head == null || n < 1) {
    return null;
  }

  LinkedListNode p1 = head;
  LinkedListNode p2 = head;

  for (int j = 0; j < n - 1; ++j) { // skip n-1 steps ahead
    if (p2 == null) {
      return null; // not found since list size < n
    }
    p2 = p2.next;
  }

  while (p2.next != null) {
    p1 = p1.next;
    p2 = p2.next;
  }

  return p1;
}
EN

Stack Overflow用户

发布于 2013-07-02 02:06:24

递归解决方案:

代码语言:javascript
运行
复制
Node findKth (Node head, int count, int k) {
    if(head == null)
        return head;
    else {
        Node n =findKth(head.next,count,k);
        count++;

        if(count == k)
            return head;

        return n;
    }
}
票数 0
EN
查看全部 29 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2598348

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档