首页 > 其他 > 详细

leetcode刷题之链表相关

时间:2021-04-07 09:23:23      阅读:26      评论:0      收藏:0      [点我收藏+]
  • q2 两数相加
    给你两个非空的链表,表示两个非负的整数。它们每位数字都是按照逆序的方式存储的,并且每个节点只能存储一位数字。请你将两个数相加,并以相同形式返回一个表示和的链表。
    思路:首先逐位相加,节点为空的表示为0,然后用新链表存储两个数的和,逐个检查新链表里面每个数据,大于等于10则减去10,且其next加一,next为空则新建0节点
 public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        ListNode rs = new ListNode(l1.val + l2.val);

        l1 = l1.next;
        l2 = l2.next;
        ListNode temp = rs;
        //先假设ab都等于0,即两个链表都为空,
        while (l1 != null || l2 != null) {
            int a = 0;
            int b = 0;
            if (l1 != null) {
                a = l1.val;
            }
            if (l2 != null) {
                b = l2.val;
            }
            //两者相加并存储,同时判断条件三个链表各自后移
            int t = a + b;
            temp.next = new ListNode(t);
            temp = temp.next;
            if (l1 != null) {
                l1 = l1.next;
            }
            if (l2 != null) {
                l2 = l2.next;
            }
        }

        temp = rs;
        //判断temp上的数值是否大于10,大于10则减去10,下一位加1,下一位为空则新建0节点再加一
        while (temp != null) {
            if (temp.val >= 10) {
                temp.val = temp.val - 10;
                if (temp.next == null) {
                    temp.next = new ListNode(0);
                }
                temp.next.val = temp.next.val + 1;
            }
            temp = temp.next;
        }
        return rs;
    }
  • q19 删除倒数第N个节点
    思路1:遍历链表,假设有m个节点,倒数第n个等于m-n+1(正数),则问题转化为:删除第(m-n+1)个节点并输出头节点,n>m,则超出范围,n=m,删除节点,并返回头节点下一个节点。
    思路2:双指针。l1,l2双指针,先让l1移动n个节点,两者再同时移动。l1移动到末尾,l2指的就是倒数第n个。
 public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode pre = new ListNode(0);
        pre.next = head;
        ListNode start = pre, end = pre;
        while(n != 0) {
            start = start.next;
            n--;
        }
        while(start.next != null) {
            start = start.next;
            end = end.next;
        }
        end.next = end.next.next;
        return pre.next;
    }

leetcode刷题之链表相关

原文:https://www.cnblogs.com/dong-qing/p/14626121.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!