• <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>
            題目大意是求解快排最壞情況下的交換次數,我們知道,快速排序在最壞情況下會退化為冒泡排序,因此快排最壞情況下的交換次數也就是冒泡排序對應的交換次數。很容易想到這一題用冒泡排序,并記錄交換次數就行了。
            這樣做看似可行,其實是行不通的,數據量是500000,由于冒泡排序的時間復雜度是O(N^2),所以問題的規模就是500000^2=2.5 * E11,一般我們認為計算機每秒的計算量是E9,因此用冒泡排序是行不通的。
            聯想有關排序的算法,我們希望這一題的時間復雜度能夠降為O(NlogN),快排、堆排序、合并排序滿足這樣的要求,可是前兩種排序方式的交換方式毫無規律可循,只剩下歸并排序。
            我們來看歸并排序,它的核心是歸并(由Merge()函數實現),就是將兩個有序序列合并為一個有序序列。由冒泡排序我們知道,交換的總次數就是初始序列中每個元素交換次數的總和,每個元素的交換次數等于該元素后面比自己小的元素的個數(因為最終比自己小的元素都在自己前面)。
            下圖是一次Merge()過程:

            可以看出,元素“1”沒有移動,元素“4”向后移動了1位,元素“10”向后移動了3位,所以本次合并共移動了4次。統計合并排序過程中所有的移動次數即可。
            本題代碼如下


            有關合并排序請參閱:
            http://m.shnenglu.com/hoolee/archive/2012/07/18/184029.html
            posted @ 2012-07-18 17:46 小鼠標 閱讀(264) | 評論 (0)編輯 收藏
            合并排序是利用了分治思想的排序方式,具有O(NlogN)的時間復雜度,與快速排序、堆排序相比,它需要N的輔助空間。它的核心部分是將兩個有序序列合并(由Merge()函數實現)。
            合并排序的基本思想是:單個元素是有序的,兩個較小的有序序列可被合并為一個較大的有序序列。
            算法描述如下:
            直接插入排序,時間復雜度O(N^2),基本操作是將一個元素插入到有序序列中。當待排序元素個數為n時,因為第一個元素是有序的,因此只需經過n - 1次插入,就能完成排序。
            單次插入的過程為:
            1.找到要插入元素在已排序部分中的位置j。
            2.將有序序列中j后面的所有元素向后移動一位,為待插入元素空出位置。
            3.將待排序元素插入j位置,保持序列有序。
            算法描述為:


            posted @ 2012-07-18 11:12 小鼠標 閱讀(919) | 評論 (0)編輯 收藏
                 摘要: 快速排序是運用了分治思想的排序方式,具有O(NlogN)的平均時間復雜度,極端情況下時間復雜度為O(N^2),跟冒泡排序一樣,但是快排的實際效率遠比最壞情況好很多。它的關鍵部分是一輪選擇(由Partition()函數完成)……所謂線性時間就是在平均O(N)的時間內找出無序序列中第k大的元素。它是以Partition()函數的劃分為依據的……  閱讀全文
            posted @ 2012-07-17 16:46 小鼠標 閱讀(3696) | 評論 (1)編輯 收藏
                 摘要: 奇數個數尋找中位數,有O(N)復雜度的算法,這里采用的方式是先排序,然后找出中間那一個,等寫到快排時在寫線性時間的算法吧。以下采用的方式分別是冒泡排序和堆排序: Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--> 1#include<...  閱讀全文
            posted @ 2012-07-16 15:52 小鼠標 閱讀(569) | 評論 (0)編輯 收藏

            冒泡排序是最基本的排序方式,很簡單,容易理解,但算法的時間復雜度為O(N^2),適合于基數不大的排序。
            下面的代碼中bsort函數完成冒泡排序,數組下標從1開始。


             

            posted @ 2012-07-16 15:22 小鼠標 閱讀(220) | 評論 (0)編輯 收藏
                 摘要: 堆排序是一種比較常用的排序方式,具有O(NlogN)的時間復雜度,它只需要一個記錄大小的空間,算法的核心是“篩選”。
            堆的存儲方式是一維數組,因為它是一棵完全二叉樹,孩子與雙親下標有簡單直接的計算方式……  閱讀全文
            posted @ 2012-07-16 11:18 小鼠標 閱讀(1171) | 評論 (0)編輯 收藏
                 摘要: Java中的基本數據類型使用"=="可以判斷操作數是否相等,對于對象則判斷這兩個對象的內存地址是否相同。Java虛擬機為了提高字符串應用效率,提供了字符串池來保存字符串常量,str1創建字符串常量"abc"時,虛擬機會先檢測字符串池中是否包含該字符串……  閱讀全文
            posted @ 2012-06-05 21:43 小鼠標 閱讀(2638) | 評論 (3)編輯 收藏
                 摘要: http://poj.org/problem?id=2251一道三維的迷宮題,要求求出最短路徑。廣度優先搜索的框架是很清晰的,就是在code的時候一些細節注意不到,就只好調啊,調啊,就這樣兩個小時就過去了%>_<%說一下代碼思路吧:1.讀入數據2.預處理迷宮,主要是給迷宮周圍加一道墻,便于統一處理3.找到起點'S',和終點'E'的坐標分別記錄在p0、p1中4.從起點開始進行廣搜,直到隊...  閱讀全文
            posted @ 2012-06-05 12:55 小鼠標 閱讀(230) | 評論 (0)編輯 收藏
            與排列相比,組合是不區分元素順序的,為了消去相同元素不同順序的干擾項,在選取每一個組合項的元素時使該元素的位序大于已選好元素的位序即可。如果題目要求所有組合項按升序輸出,只需事先將所有元素排序即可。

            posted @ 2012-05-27 10:03 小鼠標 閱讀(269) | 評論 (0)編輯 收藏
            http://acm.nyist.net/JudgeOnline/problem.php?pid=541
            這是省賽的第二題。
            題意:把一個整數拆分成若干份,每一份相加的和為這個數,求這些數最大的積。
            如果能夠分析出應把原數拆為3+3+3+3+3……,接下來需要的就是大數運算了(悲劇的是我們當時沒有分析出來):)。java中有BigInteger類來處理里大整數,比用C語言模擬大數運算方便的多。
            這是我的第一道java大數題,感覺寫的還有待改進,用的不熟練。

            posted @ 2012-05-24 00:13 小鼠標 閱讀(217) | 評論 (0)編輯 收藏
            僅列出標題
            共13頁: First 5 6 7 8 9 10 11 12 13 
            <2012年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            • 1.?re: 線段樹
            • 是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
              加油,祝你好運啦!
            • --小鼠標
            • 2.?re: 線段樹
            • 對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
            • --傷心的筆
            • 3.?re: poj1273--網絡流
            • 過來看看你。
            • --achiberx
            • 4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
            • 膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
            • --Hang
            • 5.?re: 快速排序、線性時間選擇
            • 博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
            • --lsxqw2004

            閱讀排行榜

            无码国内精品久久人妻麻豆按摩| 久久婷婷色香五月综合激情| 亚洲乱码精品久久久久..| 亚洲国产成人久久精品影视| 国产情侣久久久久aⅴ免费| 欧美日韩精品久久久久| 99久久香蕉国产线看观香| 2021久久精品免费观看| 99久久精品免费看国产一区二区三区 | 久久亚洲国产成人影院网站| 久久国产影院| 99久久香蕉国产线看观香| 国内精品久久久久久久久电影网| 久久狠狠爱亚洲综合影院| 久久久噜噜噜久久中文福利| 国内精品久久国产大陆| 国产精品成人精品久久久| 中文字幕无码av激情不卡久久| 少妇无套内谢久久久久| 国产∨亚洲V天堂无码久久久| 国产精品毛片久久久久久久| 国产巨作麻豆欧美亚洲综合久久| 久久久人妻精品无码一区| 97久久国产露脸精品国产| 72种姿势欧美久久久久大黄蕉| 久久99毛片免费观看不卡| 久久久久99精品成人片牛牛影视| 伊人久久大香线蕉AV一区二区| 精品人妻久久久久久888| 国产精品免费久久久久影院| 囯产精品久久久久久久久蜜桃| 精品熟女少妇a∨免费久久| 青青青青久久精品国产h久久精品五福影院1421 | 无码人妻精品一区二区三区久久| 久久亚洲国产成人精品性色| 久久e热在这里只有国产中文精品99| 久久久久99这里有精品10| 爱做久久久久久| 久久无码人妻一区二区三区午夜 | 久久伊人精品青青草原高清| 精品一二三区久久aaa片|