• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Fly me to the moon

            the beauty of C++

            wrong

                感謝Will同學指出的問題,我仔細思考后發(fā)現(xiàn)不只是代碼的問題,算法思想上就有錯了,我沒有在每次交換后保持兩個子序列的有序性,這樣就無法保證i和j指向正確的位置,而如果想要保持子序列有序,雖然可以引入一個臨時變量并通過交換實現(xiàn),但算法復雜度就不是線性的了,所以結(jié)論是暫時沒有可以簡單實現(xiàn)的線性時間原地歸并。事實上,有一些paper描述了很多線性時間原地歸并的算法,但是復雜度都相當高,感興趣的朋友可以自行g(shù)oogle。
                為了不誤導大家,把題目改了,至于下面的筆試題,希望牛人給予解答啊,謝謝。

            ---------------------------------------原文分割線-----------------------------------------------
                快要找工作了,現(xiàn)在在回顧一些算法和數(shù)據(jù)結(jié)構(gòu)的知識,除了看書,爭取每天挑一兩道有趣的題目來練練手。本人沒參加過ACM,解算法題的實力也相當菜鳥,但本人對于任何能夠鍛煉思維能力的題目都相當熱衷,不怕做不出來,就怕不敢做,做多了,思考多了,總是有幫助的,呵呵,所以希望各位看到我的文章中有錯誤的地方請不吝賜教,在下感激不盡。
            Share is happiness.

                今天的題目是在網(wǎng)上看到的,ms是一道baidu的筆試題:
                給定一個序列a[0...n-1]和一整數(shù)m,滿足0<=m<=n-1,且a[0...m-1]和a[m...n-1]都為有序子序列,要求設計一個時間復雜度為O(N),空間復雜度為O(1)的算法,實現(xiàn)將這兩個子序列合并為一個完整的有序序列a[0...n-1]。

                題意很簡單,就是要設計一個線性時間的原地歸并算法,我給出的思路:
                從左到右遍歷數(shù)組,將當前未遍歷元素中的最小值置換到它所應在的位置。這個簡單的描述有點像選擇排序,但選擇排序O(N^2)的復雜度明顯是不允許的,這里,利用兩個子序列已有序的性質(zhì),我們可以設計更高效的O(N)算法:首先易知未遍歷元素中的最小值必定是兩個子序列的最小值中的更小者,將改值交換到它應在的位置;利用有序性,可以在遍歷過程中分別記錄兩個子序列的當前最小元素的位置,這樣就省去了選擇排序中每次都要遍歷剩余序列找出最小值的開銷,每次遍歷內(nèi)部為常數(shù)次的比較和交換操作,所以整個算法的時間復雜度為O(N)。

            posted on 2009-09-16 11:07 翼帆 閱讀(484) 評論(2)  編輯 收藏 引用 所屬分類: 算法

            評論

            # re: 線性時間原地歸并[未登錄] 2009-10-05 01:24 Will

            程序有點問題:
            比如{4,5,1,2,3}  回復  更多評論   

            # re: wrong 2009-10-05 11:57 翼帆

            謝謝Will  回復  更多評論   

            導航

            <2009年10月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            欧美粉嫩小泬久久久久久久 | 国产福利电影一区二区三区久久老子无码午夜伦不 | 合区精品久久久中文字幕一区 | 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 精品999久久久久久中文字幕| 久久婷婷五月综合97色| 秋霞久久国产精品电影院| 理论片午午伦夜理片久久| 国产欧美久久一区二区| 91精品国产色综合久久| 久久久久亚洲AV综合波多野结衣| 中文字幕精品无码久久久久久3D日动漫 | 久久丫精品国产亚洲av不卡| 国产午夜精品理论片久久 | 2020最新久久久视精品爱| 国产精品久久久香蕉| 狠狠色丁香婷婷久久综合不卡| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 亚洲国产精品狼友中文久久久| 99久久综合狠狠综合久久止| 伊人久久五月天| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久WWW免费人成—看片| 精品无码久久久久国产| 亚洲人AV永久一区二区三区久久 | 久久国产精品免费一区| 亚洲精品乱码久久久久久蜜桃图片| 久久国产香蕉视频| 国产福利电影一区二区三区久久老子无码午夜伦不 | 国产成人精品免费久久久久| 久久人与动人物a级毛片| 久久久久久毛片免费看| 国产精品成人99久久久久 | 久久精品人妻中文系列| 国产69精品久久久久观看软件 | 久久无码AV中文出轨人妻| 久久久精品人妻无码专区不卡 | 久久精品免费大片国产大片| 久久久久久亚洲精品无码| 久久影视国产亚洲| 亚洲欧美一级久久精品|