求助算法是否有错误

2018-03-10 10:55:22 +08:00
 letianqiu

目前的想法是开一个 N 的 array 作为桶,遍历这 N 个数,每次拿这个数乘以 N 然后再取整,作为下标 idx。这个数就放入下标为 idx 的桶中。最后合并桶里的元素。

2307 次点击
所在节点    程序员
7 条回复
xml123
2018-03-10 14:03:38 +08:00
正确的。
首先在给定的序列中插入新的数不会使求和的式子变小,因为 |a-b|<=|a-c|+|c-b| 。
然后把你最后生成的数列按桶分成若干组(设有 m 个桶,m<=n ),每一组最后插入该组第一个数,下面证明修改后的序列满足不等式。
把求和分成两部分,y_i 和 y_i-1 在同一组里的,不在同一组里的。
同一组里的元素为分布在长度为 1/n 区间内的实数,任意两数之差绝对值小于 1/n,同一组 k 个数相邻元素差的绝对值之和小于(k-1)/n,由于一共有 n+m 个数,m 组,所以这些和小于 1。
不同组元素的差的绝对值之和可以看出等于第一个数与最后一个数差的绝对值,该值小于 1。
所以两部分之和小于 2。
(稍微修改证明过程可以证明和小于 2-2/n,应该是你给出的算法的上界了。)
ytterbium
2018-03-10 14:41:43 +08:00
简单点说就是,每个桶 i 里差总和小于等于(k_i-1)/n,所有桶内和小于等于 sum{(k_i-1)/n}=(n-h)/n<1,h 是非空桶的个数。桶之间的差绝对值之和是在有序序列上算的,小于等于 1。所以两部分总和小于 2。
letianqiu
2018-03-10 15:49:35 +08:00
@xml123
@ytterbium 感谢你们两位啊,我只是凭直觉想出的这个算法,但是苦于无法证明。
letianqiu
2018-03-10 21:06:10 +08:00
@xml123
@ytterbium 如果要求和的上界是 1+eplison,算法该怎么调整? 感觉每个桶内部也要保持有序,退化成桶排序的话无法保证 O(n)。
ytterbium
2018-03-10 21:18:39 +08:00
桶数增大,由 n 换成 m,m>n,m 和 eplison 什么关系没想好,不过复杂度就是 O(m)了
ytterbium
2018-03-10 21:19:53 +08:00
题目说的线性复杂度,O(m)也是线性,还算符合要求吧
ytterbium
2018-03-10 21:21:34 +08:00
如果 m 可以写成 eplison 的表达式,就是关于 eplison 的线性算法,O(eplison)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/436745

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX