/** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *next; * }; */ struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){ struct ListNode *Node=list1; if(list1==NULL) { return list2; } while(list2!=NULL) { while(list1->next!=NULL) { if(list2>=list1->val&&list2<=list1->next->val) { list2->next=list1->next; list1->next=list2; } list1->next; } list1->next=list2; list2=list2->next; } return Node; }优化该代码
时间: 2024-04-09 16:28:48 浏览: 11
要优化该代码,可以考虑以下几点:
1. 避免多次遍历链表:在当前的代码中,使用了嵌套的 while 循环来遍历链表,这样会导致时间复杂度增加。我们可以优化为只遍历一次链表。
2. 使用指针操作代替值比较:在当前的代码中,使用了 if 语句来比较节点的值,这样会增加代码的复杂性。我们可以通过指针操作来完成节点的插入。
3. 处理链表末尾节点:当前的代码没有处理合并后链表的末尾节点,需要额外处理。
下面是优化后的代码:
```
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {
if (list1 == NULL) {
return list2;
}
if (list2 == NULL) {
return list1;
}
struct ListNode dummy;
struct ListNode* tail = &dummy;
while (list1 != NULL && list2 != NULL) {
if (list1->val <= list2->val) {
tail->next = list1;
list1 = list1->next;
} else {
tail->next = list2;
list2 = list2->next;
}
tail = tail->next;
}
if (list1 != NULL) {
tail->next = list1;
} else {
tail->next = list2;
}
return dummy.next;
}
```
这样优化后的代码在时间复杂度上更加高效,并且处理了链表的末尾节点。