从链接列表结尾找到第n个元素
时间:2020-02-23 14:34:12 来源:igfitidea点击:
假设:
我们不知道LinkedList的大小,否则我们可以直接迭代并找到(长-N)TH节点
这个问题的算法是:
- 使用两个指针FirstPtr和SecondPtr并初始化链接列表的负责人
- 通过N-1节点移动FirstPtr。
- 递增pricthtptr和secondptr,直到firstptr.next不等于null。
- 第二个来自终端节点的第n个。
Java计划为此:
package org.igi.theitroad; public class LinkedList{ private Node head; private static class Node { private int value; private Node next; Node(int value) { this.value = value; } } public void addToTheLast(Node node) { if (head == null) { head = node; } else { Node temp = head; while (temp.next != null) temp = temp.next; temp.next = node; } } public void printList() { Node temp = head; while (temp != null) { System.out.format("%d ", temp.value); temp = temp.next; } System.out.println(); } public Node nthFromLastNode(Node head,int n) { Node firstPtr=head; Node secondPtr=head; for (int i = 0; i < n; i++) { firstPtr=firstPtr.next; } while(firstPtr!=null) { firstPtr=firstPtr.next; secondPtr=secondPtr.next; } return secondPtr; } public static void main(String[] args) { LinkedList list = new LinkedList(); //Creating a linked list Node head=new Node(5); list.addToTheLast(head); list.addToTheLast(new Node(6)); list.addToTheLast(new Node(7)); list.addToTheLast(new Node(1)); list.addToTheLast(new Node(2)); list.printList(); //Finding 3rd node from end Node nthNodeFromLast= list.nthFromLastNode(head,3); System.out.println("3th node from end is : "+ nthNodeFromLast.value); } }
逻辑上我们的LinkedList看起来像如下:
彩色节点从最后表示第3节点。
运行上面的程序,我们将获取以下输出:
5 6 7 1 2 3th node from end is : 7