题解 | #【双指针】输出单向链表中倒数第k个结点#

输出单向链表中倒数第k个结点

https://www.nowcoder.com/practice/54404a78aec1435a81150f15f899417d

import java.util.*;
import java.util.stream.*;
import java.util.regex.*;

public class Main {
  public static void main(String[] args) {
    Scanner in = new Scanner(System.in);

    // while (in.hasNextInt()) {
    //   // 方法一:不讲武德
    //   int n = in.nextInt();
    //   int[] a = new int[n];
    //   for (int i = 0; i < n; i++) {
    //     a[i] = in.nextInt();
    //   }
    //   int k = in.nextInt();
    //   System.out.println(a[n - k]);
    // }

    while (in.hasNextInt()) {
      // 方法二:ListNode 双指针
      int n = in.nextInt();
      ListNode node = new ListNode(in.nextInt());
      ListNode head = node;
      ListNode headK = node;

      for (int i = 1; i < n; i++) {
        node.next = new ListNode(in.nextInt());
        node = node.next;
      }
      int k = in.nextInt();

      while (head.next != null) {
        head = head.next;
        k--;
        if (k <= 0) {
          headK = headK.next;
        }
      }

      System.out.println(headK.val);
    }
  }
}

class ListNode {
  int val;
  ListNode next;

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

  @Override
  public String toString() {
    return String.valueOf(val);
  }
};


全部评论

相关推荐

04-03 22:39
重庆大学 Java
点赞 评论 收藏
分享
04-08 13:31
已编辑
门头沟学院 前端工程师
D0cC:京东营收1万多亿人民币,阿里9000多亿,虽然他俩利润都没腾讯和字节多,但是很恐怖了啊,负担了多少打工人的薪水
投递拼多多集团-PDD等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务