zoukankan      html  css  js  c++  java
  • Leetcode 23

    题目

    https://leetcode.com/problems/merge-k-sorted-lists/

    题意

    给出N条有序的整数链表,要求将其合并成一条有序的整数链表。

    思路

    author's blog == http://www.cnblogs.com/toulanboy/

    (1)其实是道水题,这道题考核对链表的熟悉运用程度和合并排序的熟悉度。

    (2)对于多个有序链表的合并,我们可以用合并排序的思想,每次对比所有链表的首元素,然后取最小的首元素放到结果链表即可。

    (3)为了实现上述的循环取数,并且保证所有数值都已经转移到新链表中。我的方案是:每次取完元素后(将该元素从原链表中删除后),我都会判断原链表是否为空;如果空,则将该链表从lists中删除。当lists空了,说明所有数都已经被转移到新链表上了。

    为了节省空间,在合并过程中,新链表中的节点都是来自原链表。

    代码

    //author's blog == http://www.cnblogs.com/toulanboy/
    /**
     * Definition for singly-linked list.
     * struct ListNode {
     *     int val;
     *     ListNode *next;
     *     ListNode(int x) : val(x), next(NULL) {}
     * };
     */
    class Solution {
    public:
        ListNode* mergeKLists(vector<ListNode*>& lists) {       
            //(1)测试数据有空链表,这我……无语了,那就先预处理一下吧。
            for(int i=0; i<lists.size(); ++i){
                if(lists[i] == NULL){
                    lists.erase(lists.begin() + i);
                    i--;
                }
            }
            //(2)如果是空的,直接不用处理了,就是NULL
            if(lists.size() == 0)
                return NULL;
            
            //(3)先给结果链表找个头~ 
            ListNode * result = NULL;
            int min_pos = 0;
            for(int i=0; i<lists.size(); ++i)
                if(lists[i]->val < lists[min_pos]->val)
                    min_pos = i;
            result = lists[min_pos];
            lists[min_pos] = lists[min_pos]->next;
            //(3.1) 如果该链表去掉该元素后,变成空链表,则将该链表从lists从剔除
            if(lists[min_pos] == NULL)
                    lists.erase(lists.begin() + min_pos);
            
            //(4)让p指向最后一个节点,方便在尾部连接新节点
            ListNode * p = result;
            //(5)下面开始用合并排序的思想,合并数列
            // 当lists为空时,说明所有链表都被合并到新链表了
            while(lists.empty() == false){
                min_pos = 0;
                for(int i=0; i<lists.size(); ++i)
                    if(lists[i]->val < lists[min_pos]->val)
                        min_pos = i;
               
                p->next = lists[min_pos];
                p = p->next;
                lists[min_pos] = lists[min_pos]->next;
                if(lists[min_pos] == NULL)
                    lists.erase(lists.begin() + min_pos);
            }
            return result;
        }//author's blog == http://www.cnblogs.com/toulanboy/
    };
    

    运行结果

    Runtime: 272 ms, faster than 16.30% of C++ online submissions for Merge k Sorted Lists.
    Memory Usage: 10.8 MB, less than 93.58% of C++ online submissions for Merge k Sorted Lists.
    
  • 相关阅读:
    第三次作业
    第二次作业
    10.30 非确定的自动机NFA确定化为DFA
    10.23 正规式、正规文法与自动机
    10.16 正规文法与正规式
    10.9 词法分析程序的设计与实现
    9.25 文法和语言总结与梳理
    9.18 语法树,短语,直接短语,句柄
    9.11 理解文法和语言
    9.4 了解编译原理
  • 原文地址:https://www.cnblogs.com/toulanboy/p/10938159.html
Copyright © 2011-2022 走看看