力扣之旅第18天(第19题:删除链表的倒数第N个结点)

(一、暴力法)

  

class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode h=new ListNode();//新定义一个新链表用来返回head链表的头结点
        h.next=head;//h.next表示head的头结点
        ListNode number=new ListNode();//定义一个number链表用来统计head链表的长度
        number=head;//number表示head的头结点
        int i=0;//定义初始长度为0
        while(number!=null){//当number不为null时,长度加1
            number=number.next;//number指向下一个结点
            i++;//长度加1
        }
        if(n==i){//如果删除的是第一个结点
            h.next=head.next;//h.next表示的头结点指向head的下一个结点head.next
            return h.next;//并且返回头结点
        }
        for(int j=0;j<i-n-1;j++){//将head指向要被删除的结点的前一位
            head=head.next;
        }
        head.next=head.next.next;//删除该节点(就是将要被删除结点的前一位的下一个结点指向被删除结点的下一个结点)
        return h.next;//返回头结点
    }
}

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值