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

请输入看板名称,例如:WOW站内搜寻

TOP