• LeetCode19.删除链表的倒数第N个节点


     我先用的第一种方法,先第一次遍历算出有节点数num,然后第二次遍历找到第num-n个节点,删除它的下一个节点,也就是第num-n节点.next = num-n节点.next.next(),然后需要注意的是找到第num-n个节点,指针需要从头节点移动num-n-1次,但是后来一直报空指针异常,我反复的检查,一步一步自己推,死活想不到,后来我直接把头节点的下一个删掉看看返回什么,才发现,示例中有一个只有一个节点的链表需要删除头节点,这样.next = .next.next当然就报错了,于是我把删除头节点的情况单独拿出来了,这是第一种方法的代码:

    1. class Solution {
    2. public ListNode removeNthFromEnd(ListNode head, int n) {
    3. ListNode h1 = head;
    4. ListNode h2 = head;
    5. int num =0;
    6. while(h1 != null){
    7. num++;
    8. h1=h1.next;
    9. }
    10. if(num == n){
    11. return head.next;
    12. }else{
    13. while(num - n-1 !=0){
    14. h2 = h2.next;
    15. num--;
    16. }
    17. h2.next = h2.next.next;
    18. }
    19. return head;
    20. }
    21. }

     我记得我之前在剑指offer里面做过一道相同的题剑指offer22.链表中的倒数第k个节点_荔枝味啊~的博客-CSDN博客,我用的是双指针,就是第一个指针先走n步,然后第二个指针和第一个指针一起完后移动,当第一个指针为空的时候,第二个指针的位置就是要删除的节点,然后写了如下代码:

    1. class Solution {
    2. public ListNode removeNthFromEnd(ListNode head, int n) {
    3. ListNode h1 = head;
    4. ListNode h2 = head;
    5. if(h1.next == null)return head.next;
    6. while(n!=0){
    7. h1 = h1.next;
    8. n--;
    9. }
    10. h1 = h1.next;
    11. while(h1 != null){
    12. h1 = h1.next;
    13. h2 = h2.next;
    14. }
    15. h2.next= h2.next.next;
    16. return head;
    17. }
    18. }

    三个示例过了但是我无法解决删除头节点的问题,于是就看题解了,题解是先创建了一个节点然后这个节点的下一个节点是头节点(其实我都没看到题目中有这个参数是val和next的构造方法),这样就很容易用.next = .next.next删除头节点了,这是题解代码和题目给出的ListNode的数据结构:

    1. /**
    2. * Definition for singly-linked list.
    3. * public class ListNode {
    4. * int val;
    5. * ListNode next;
    6. * ListNode() {}
    7. * ListNode(int val) { this.val = val; }
    8. * ListNode(int val, ListNode next) { this.val = val; this.next = next; }
    9. * }
    10. */
    11. class Solution {
    12. public ListNode removeNthFromEnd(ListNode head, int n) {
    13. ListNode dummy = new ListNode(0, head);
    14. ListNode first = head;
    15. ListNode second = dummy;
    16. for (int i = 0; i < n; ++i) {
    17. first = first.next;
    18. }
    19. while (first != null) {
    20. first = first.next;
    21. second = second.next;
    22. }
    23. second.next = second.next.next;
    24. ListNode ans = dummy.next;
    25. return ans;
    26. }
    27. }
  • 相关阅读:
    java集合专题_集合体系介绍_集合遍历(1)
    Redis 主从复制
    第一次写计算机论文无从下手怎么办?(二) - 易智编译EaseEditing
    STM32CUBEMX开发GD32F303(11)----ADC在DMA模式下扫描多个通道
    VUE右键菜单 vue-contextmenujs的使用
    08.29web自动化测试
    列表推导式、集合推导式、字典推导式、生成器
    【示波器专题】示波器的交流耦合模式与注意事项
    npm install 报错常见的解决方法
    在全链路追踪中加入对方法(Method)追踪
  • 原文地址:https://blog.csdn.net/qq_61009660/article/details/132999355