Prob_Solve 板


LINE

※ 引述《DJWS (...)》之銘言: : 推 springman: 其實就是用 median of median 的演算法,只是找到 10/14 09:24 : → springman: median of median m 之後,用 binary search 找出 10/14 09:25 : → springman: 每個排序的陣列中有幾個元素比 m 小,看看要找的 10/14 09:25 : → springman: median 比 m 大還是比 m 小。 10/14 09:26 : → springman: 雖然每次可能只能減少 1/4 的元素,不過沒關係。 10/14 09:26 : → springman: 每次花的時間,理論值是 O(n) 找 median of median 10/14 09:27 : → springman: O(n log n) 找比 m 小的元素個數。 10/14 09:28 : → springman: 總共應該只需要花 O(log n) 次 10/14 09:28 : → springman: 每次都要使用排序好的陣列。 10/14 09:29 : → yr: 可是 problem size 不是 n^2 嗎?這樣上面的 n 都要換成 n^2 10/14 11:27 : 推 springman: 因為 n 個 size 為 n 的數列已經排序好了 10/14 13:12 : → springman: 要算有幾個元素比 m 小時,並不是拿 n^2 個元素來比較 10/14 13:13 : → springman: 而是去每個數列做 binary search,所以時間是 O(nlogn) 10/14 13:13 : → DJWS: 第二回合要怎麼找median of median? 10/14 15:00 : 推 springman: 每一個數列是哪個範圍的元素在候選名單中需要記下來 10/14 18:21 : → springman: 候選範圍的資料的 median 同樣可以找 median。 10/14 18:21 : 推 FRAXIS: 其實找median of median可以用排序 不影響複雜度 10/14 20:09 : → FRAXIS: 但是會比較容易作 10/14 20:09 : → DJWS: 應該是不得不排序 為了知道「減少1/4的元素」來自哪些陣列 10/14 23:04 :   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 我搞錯了 這一句當我沒說... : → DJWS: springman的方法看起來可行 是O(n logn logn) 10/14 23:05 : ※ 編輯: DJWS (111.250.80.176), 10/14/2014 23:51:31 : 推 FRAXIS: 但是要怎麼證明一次可以刪除O(n/4)個元素? 10/15 01:27 : → FRAXIS: 因為到最後每一列的元素都不一樣多 原本median of median 10/15 01:27 : → FRAXIS: 的證明法好像不能直接套用 10/15 01:28 昨天睡覺時用力想了一陣 事實上不需要跑 binary search,也不必跑 partition 這邊重新整理一下 給定 n 個長度 n 已排序陣列,找第 k 小的元素 每個陣列都有兩個指標 low = 0 和 high = n-1 O(n) 每個陣列的大小 size = high - low + 1 O(n) 每個陣列的中位數 array[(low + high) / 2] O(n) 上述n個中位數的中位數,設為x O(n) 套用中位數演算法 注意到上述n個中位數,有一半比x小 (大) 注意到其所對應的陣列,每個陣列都有一半比x小 (大) 注意到有1/4的元素比x小 (大) 只有第一回合! 依序掃描n個中位數 O(n) 比x小(大)的中位數 其所對應的陣列,預計刪除小(大)的那一半 也就是 low = (low + high) / 2 + 1; O(1) (或者 high = (low + high) / 2 - 1;) 預計更新陣列大小為 size = high - low + 1 O(1) 累計欲刪除的元素數量 y (小的那些) O(1) 如果第k個元素小於等於 y,那麼就刪除最大的那 1/4,下個回合找第 k 小的元素 否則就刪除最小的那 1/4,下個回合找第 k = Σsize - y 大的元素 得再掃描一遍n個中位數,進行實際刪除 總共 O(logn) 個回合 n^2元素每回合減少1/4 的話... 總共 O(logn) 個回合 每回合有一半的陣列少了一半 時間複雜度 O(n logn) --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 111.250.79.164
※ 文章網址: http://webptt.com/m.aspx?n=bbs/Prob_Solve/M.1413328594.A.3F3.html ※ 編輯: DJWS (111.250.79.164), 10/15/2014 07:43:07
1F:推 FRAXIS: 如果每回合都有一半陣列被刪除一半 那頂多只有O(lg n)回合 10/15 07:42
2F:→ DJWS: 是這樣嗎? 要怎麼證明? 10/15 07:43
3F:→ DJWS: 好像是你說的這樣沒錯 我改一下 10/15 07:47
※ 編輯: DJWS (111.250.79.164), 10/15/2014 07:47:28
4F:→ DJWS: 然後這個方法也可以套用到已排序二維陣列 上述步驟都是O(1) 10/15 07:51
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 我又講錯了 這句話當我沒說...
5F:推 FRAXIS: 太強啦~~ 10/15 07:56
6F:→ DJWS: 感謝springman的想法 10/15 07:59
※ 編輯: DJWS (111.250.79.164), 10/15/2014 08:06:39
7F:推 springman: 您們已經想得比我多了 ^_^。 10/15 08:17
8F:→ DJWS: FRAXIS 這題目有人做過嗎? 10/15 08:29







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Gossiping站內搜尋

TOP