码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode_合并两个有序链表

时间:2019-01-06 11:16:23      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:指针   return   lis   leetcode   sts   题解   循环   code   lse   

不敢确定自己理解的一定正确,

但是可以讲得通。

此题解法重点在于开了一个新的头结点。

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1,ListNode* l2) {
        ListNode* head = new ListNode(0);
        ListNode* p = head;        //p和head指向同一个头结点

        while(l1 != NULL && l2 != NULL) {
            if(l1->val <= l2->val) {
                p->next = l1;
                l1 = l1->next;
            } else {
                p->next = l2;
                l2 = l2->next;
            }
            p = p->next;
        }
        if(l1 != NULL) p->next = l1;
        if(l2 != NULL) p->next = l2;
        return head->next;
    }
};

感觉比较难以理解的就是head和p是虽然是两个指针,

但是一开始的时候指向的都是new ListNode(0)开辟出来的那一块内存  //不知道自己这么理解对不对

所以在while循环中虽然没有对head有过什么操作,只是对p进行操作,

但是最后,返回的却是head->next。

leetcode_合并两个有序链表

标签:指针   return   lis   leetcode   sts   题解   循环   code   lse   

原文地址:https://www.cnblogs.com/huangming-zzz/p/10227338.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!