class Solution {
public:
ListNode* mergeTwoLists(ListNode *a, ListNode *b) {
if ((!a) || (!b)) return a ? a : b;
ListNode head, *tail = &head, *aPtr = a, *bPtr = b;
while (aPtr && bPtr) {
if (aPtr->val < bPtr->val) {
tail->next = aPtr; aPtr = aPtr->next;
} else {
tail->next = bPtr; bPtr = bPtr->next;
}
tail = tail->next;
}
tail->next = (aPtr ? aPtr : bPtr);
return head.next;
}
ListNode* merge(vector <ListNode*> &lists, int l, int r) {
if (l == r) return lists[l];
if (l > r) return nullptr;
int mid = (l + r) >> 1;
return mergeTwoLists(merge(lists, l, mid), merge(lists, mid + 1, r));
}
ListNode* mergeKLists(vector<ListNode*>& lists) {
return merge(lists, 0, lists.size() - 1);
}
};
这是力扣的原题官方解答,分治合并,我有几个问题,来个认真负责任的大佬
问:if ((!a) || (!b)) return a ? a : b;这段代码有什么意义呢,为什么不写成if ((a) || (b))
问:tail->next = (aPtr ? aPtr : bPtr);这段代码的优先级是什么,为什么不写成(tail->next = aPtr) ? aPtr : bPtr;
问:int mid = (l + r) >> 1;这段代码什么意思,为什么不去写成int mid = (l + r) /2,希望能讲详细一点
问: ListNode head, *tail = &head,我为什么不能写成 ListNode &head, tail = head
问:ListNode mergeTwoLists(ListNode *a, ListNode b)为什么不能写成ListNode mergeTwoLists(ListNode a, ListNode b)
来个负责任的大佬