Prob_Solve 板


LINE

※ 引述《dreamoon (大笨蛋小月唷!)》之銘言: : ※ 引述《DJWS (...)》之銘言: : : 依序掃描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 大的元素 : 對於這裡我有點困惑 : 若k<=y,刪除叫大的那些數是沒問題的,因為那些數一定比第k個數還大 : 但是當k>y時,真的能刪除較小的那一部分嘛? : 例如說現在有7*7的矩陣 : 1, 2, 3, 4, 5, 6, 7 : 8, 9,10,11,12,13,14 : 15,16,17,18,19,20,21 : 22,23,24,25,26,27,28 : 29,30,31,32,33,34,35 : 36,37,38,39,40,41,42 : 43,44,45,46,47,48,49 : 並且我要找的數是第17小的數 : 但比較小的那部分卻只有16個數 : 於是按照這個演算法我們就會把真正的第17小的數給移除了0.0(我沒理解錯的話...) 其實把DWJS的方法稍微改一下就可以了。 對於目前的n條序各列改中位數 O(1) n個中位數找中位數(MoM) O(n) 對每一條序列用binary search找比MoM大和小各有多少個 O(n logn) 會有 n_l個比MoM小,n_r個比MoM大,選擇目標的那一邊。 更新序列的 head和 tail O(1) 看把n_l或n_r被砍掉的部份算到全部被移掉的N_L和N_R中。 重複以上動作直到MoM收斂。 這個動作至多進行 O(log n)次,分析如下: 考慮n條長度為n的序列 每次動作至少有n/2條會被移除一半 也就是說,至多只要 2 log n次,所有的序列都會只剩下一個元素。 因此在經過 O(n log n log n)的時間後,還剩下O(n)個元素要找第k大的數。 再加上最後的O(n),時間複雜度還是 O(n log n log n)。 ps. 跑實驗的結果 random input大概只需要 log n個 iteration就會收斂了。 幾乎不會跑到 2 log n個iteration。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.109.23.210
※ 文章網址: http://webptt.com/m.aspx?n=bbs/Prob_Solve/M.1413369090.A.B9C.html
1F:推 FRAXIS: 用這個方法 解每行每列都排序的情況 就變成O(n lg n)了 10/15 20:17
2F:推 dreamoon: 我猜若只需求O(n log n log n)的話 10/15 20:48
3F:→ dreamoon: 甚至可以直接random取一個數代替MoM就行了 10/15 20:49
4F:→ chz: random取不保證收斂速度阿。 10/16 00:57
5F:推 DJWS: 用了binary search之後 每次動作不會有n/2條被移除"一半" 10/16 08:31
6F:推 DJWS: 不過用average case來分析的話 應該就對了 10/16 08:35
7F:→ DJWS: 然後這個方法拿來解每行每列都排序 依然是O(n logn logn) 10/16 08:36
8F:推 FRAXIS: 應該是變成至少有一半的列至少移除一半 10/16 21:01
9F:→ chz: n條的一半不就是 n/2條嗎? 10/17 00:09
10F:推 FRAXIS: 如果每行每列都排序 partition可以在O(n)時間做完 10/17 01:05
11F:推 DJWS: 有可能刪nl或nr,nl nr大小未知,為什麼是至少移除一半? 10/17 05:50
12F:推 DJWS: 每行每列都排序 只有第一回合是這樣 10/17 05:52







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燈, 水草

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

TOP