Prob_Solve 板


LINE

我也還沒找到 O(n) 的作法,不過分享一下我到目前為止的想法。 首先假設這 K 個 occurrences list 各自是排序過的 lists = {list_1, list_2, ..., list_K} where list_i = {p_i1, p_i2, ...} 不失一般性的假設 |list_1| (list_1 的元素個數) 是最小的 我們知道 the smallest window 一定會包含 p_11, p_12, ... 的其中一個 假設包含 p_1j 那對 list_i (i != 1) 來說,所要找的 window 一定會包含 a_i = max {p_ik | p_ik <= p_1j} 和 b_i = min {p_ik | p_ik >= p_1j} 的其中一個 於是,我們就可以得到一個小一點的問題, lists = {list_1, list_2, ..., list_K} where list_1 = {p_1j}, list_i = {a_i, b_i} 這個問題的大小是 O(K) ,如果可以在 O(K) 的時間得到答案的話, 我們就可以用 O(N) 的時間得到原問題的答案: // all indices start from 1 Given lists swap( lists[1], arg min { |lists[i]| } ) // O(N) for i = 2, ..., K // This for loop can be done in O(N) lists[i].push_back(INF) // 加入這兩個邊界可以讓下面的程式簡單 lists[i].push_front(-INF) // 一些 a = { 0, 0, ..., 0} // size = K b = { 1, 1, ..., 1} // size = K answer = INF for i = 1, ..., |lists[1]| for j = 2, ..., K while lists[j][a[j] + 1] <= lists[1][i] a[j] = a[j] + 1 while lists[j][b[j] + 1] >= lists[1][i] b[j] = b[j] + 1 sub_lists[1] = { lists[1][i] } for j = 2, ..., K sub_lists[j] = { lists[j][a[j]], lists[j][b[j]] } tmp = solve(sublists) if (tmp < answer) answer = tmp return tmp 其中 a[j] = a[j] + 1 和 b[j] = b[j] + 1 的總運算量是 O(N) 所以,整個的運算量是 O(N) + O(N) + O(N) + O(|lists[1]| * O(solve(sublists)) 如果 O(solve(sublists)) = O(K) 的話,因為 |lists[1]| <= N/K (因為他是最小的) 所以 O(|lists[1]| * O(solve(sublists)) = O(N) 整個的運算量就會是 O(N) 另外,因為 solve(sublists) 這個問題和原本的問題有很高的相似性, 如果原本的問題可以在 O(N) 的時間算完, 那 solve(sublists) 就可以在 O(K) 的時間算完。 反過來說,如果 solve(sublists) 不可能 在 O(K) 的時間算完 那原問題也 不可能 在 O(N) 的時間算完 (原命題為真,則逆否命題也為真) 很可惜的,解 sublists 我目前只想到 O(K logK) 的算法, O(K) 只能得到一些上界 補充1 : solve(sublists) 可以再換成另一個等價的問題: 給定 a = { a_1, ..., a_(K-1) }, b = { b_1, ..., b_(K-1) } for all i, a_i, b_i >= 0, a 和 b 並沒有被排序過,且 a_i > 0 iff b_i > 0 目標:minimize A + B subject to: for all i, either a_i <= A or b_i <= B 幾個可以在 O(K) 算出來,可是不知道有沒有用的東西: max a_i (A <= max a_i) max b_i (B <= max b_i) max {min {a_i, b_i}} a 的第 k 名 b 的第 k 名 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 140.112.4.176
1F:推 seanwu:不能sort or merge真的超煩orz 03/08 23:22
2F:→ seanwu:不過這篇這個結論挺強的說不定有機會XD 03/08 23:22
3F:→ seanwu:幫補個等價變形 {(ai,bi)} , ai<0, bi>0, i=1..K-1 03/08 23:23
4F:→ seanwu:求 min{ max{bj|(for all aj<ai)}-ai|(for all i)} 03/08 23:24







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

請輸入看板名稱,例如:e-shopping站內搜尋

TOP