麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

合并k個排序鏈表

2019-11-14 09:46:57
字體:
來源:轉載
供稿:網友

分治法。 這道題我是先用自己的方法做了出來,花費了很多時間,調試了很多次。最后和網上的解法對比了一下,發現自己的合并兩個鏈表的函數太繁雜,包含太多if else,典型的初學者思維,代碼不簡潔還容易出錯。所以網友的方法是在是值得學習,建議記下來,這是公式化的合并雙鏈表法。

我的C++代碼:

/** * Definition of ListNode * class ListNode { * public: * int val; * ListNode *next; * ListNode(int val) { * this->val = val; * this->next = NULL; * } * } */class Solution {public: /** * @param lists: a list of ListNode * @return: The head of one sorted list. */ ListNode *mergeKLists(vector<ListNode *> &lists) { int len = lists.size(); if (len == 0) { return NULL; } return mLists(lists,0,len-1); } ListNode *mLists(vector<ListNode*> &lists, int left, int right) { if (left == right) { return lists[left]; } if (right - left == 1) { return merge(lists[left],lists[right]); } ListNode * temp1 = mLists(lists,left,(left+right)/2); ListNode * temp2 = mLists(lists,(left+right)/2+1, right); return merge(temp1, temp2); } ListNode *merge(ListNode* l, ListNode *r) { ListNode * root = NULL,*temp=NULL; if (l==NULL && r==NULL) { return root; } if (l==NULL) { temp = new ListNode(r->val); root = temp; r = r->next; } else if (r == NULL) { temp = new ListNode(l->val); root = temp; l=l->next; } else if (l->val > r->val) { temp = new ListNode(r->val); r= r->next; root = temp; } else { temp = new ListNode(l->val); l = l->next; root = temp; } while(l!=NULL || r!=NULL) { if (l==NULL) { while (r!=NULL) { temp->next = new ListNode(r->val); r = r->next; temp = temp->next; } }else if (r==NULL) { while (l!=NULL) { temp->next = new ListNode(l->val); l = l->next; temp = temp->next; } } else if (l->val > r->val) { temp->next = new ListNode(r->val); r= r->next; temp = temp->next; } else { temp->next = new ListNode(l->val); l = l->next; temp = temp->next; } } return root; }};

網友的C++代碼,他用了自底向上的迭代(我的是遞歸):

class Solution {public: ListNode *mergeKLists(vector<ListNode *> &lists) { if (lists.size() == 0) return NULL; int n = lists.size(); while (n > 1) { int k = (n + 1) / 2; for (int i = 0; i < n / 2; ++i) { lists[i] = mergeTwoLists(lists[i], lists[i + k]); } n = k; } return lists[0]; } ListNode *mergeTwoLists(ListNode *l1, ListNode *l2) { ListNode *head = new ListNode(-1); ListNode *cur = head; while (l1 && l2) { if (l1->val < l2->val) { cur->next = l1; l1 = l1->next; } else { cur->next = l2; l2 = l2->next; } cur = cur->next; } if (l1) cur->next = l1; if (l2) cur->next = l2; return head->next; }};

除了上面的合并方法,其他合并雙鏈表的方法:

1.

class Solution {public: ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) { if (!l1) return l2; if (!l2) return l1; if (l1->val < l2->val) { l1->next = mergeTwoLists(l1->next, l2); return l1; } else { l2->next = mergeTwoLists(l1, l2->next); return l2; } }};

2.

class Solution {public: ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) { if (!l1) return l2; if (!l2) return l1; ListNode *head = l1->val < l2->val ? l1 : l2; ListNode *nonhead = l1->val < l2->val ? l2 : l1; head->next = mergeTwoLists(head->next, nonhead); return head; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天天黄色片 | 亚洲骚妻 | 国产精品探花在线观看 | 久久国产亚洲视频 | 成人免费在线播放 | 娇妻被各种姿势c到高潮小说 | 成人福利在线播放 | 国产视频第一区 | 中文字幕涩涩久久乱小说 | 精品一区二区三区免费 | 日韩精品无码一区二区三区 | 1区2区3区国产 | 国产成年免费视频 | 欧美爱爱视频 | 天天夜干 | 中国女警察一级毛片视频 | 天天碰夜夜操 | 亚洲午夜视频在线 | 日本在线观看高清完整版 | 色阁阁69婷婷 | 免费一级欧美大片视频 | 久久影城| av在线等| 一级电影在线观看 | 龙床上的呻吟高h | 国产成人精品免费视频大全办公室 | 国产正在播放 | 最新一区二区三区 | 久久一区三区 | av在线免费看片 | 免费看成人av | 久在线观看福利视频69 | 欧美一级精品 | 免费欧美一级视频 | 午夜视频中文字幕 | 国产精品www | 国产在线播放一区二区 | 国产欧美一区二区三区免费看 | 日本在线视 | 成年人免费黄色片 | 91中文字幕在线观看 |