- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在尝试想出一个快速算法来计算 数量 b[i]= med |y_i+y_j|, 1<=j!=i<=n
什么时候y_1,...,y_n
已经排序(所以 b[]
是一个 vector 与 y[]
长度相同).我将假设 y[]
的所有元素是独一无二的 并且 n 是偶数。
因此,下面的代码计算了 b[i]
是天真的(O(n**2)
)方式:(为了方便,我用 R 写了这个,但我是语言不可知论者)
n<-30
a_fast<-b_slow<-rep(NA,n)
y<-sort(rnorm(n,100,1))
z<-y
for(i in 1:n){
b_slow[i]<-median(abs(y[-i]+y[i]))
}
我在 O(n)
中有一个初步的建议——如下—— .但只有在 y[]
时才有效包含正数。
我的问题是:我应该如何改变快速算法在y[]
时也能工作包含正面和负数?这可能吗?
和下面的代码(暂定)O(n)
方法(为了方便,我用 R 写了这个,但我是语言不可知论者)
tryA<-floor(1+(n-1)/2+1)
tryB<-floor(1+(n-1)/2)
medA<-y[tryA]
medB<-y[tryB]
for(i in 1:(tryA-1)){
a_fast[i]<-medA+y[i]
}
for(i in tryA:n){
a_fast[i]<-medB+y[i]
}
简单的说明性示例。如果我们有一个长度为 4 的 vector
-3, -1, 2, 4
然后,例如对于 i=1,3 个绝对成对和是
4 1 1
他们的中位数是 1。
然后,例如对于 i=2,3 个绝对成对和是
4 1 3
他们的中位数是 3。
这是一个更长的例子,有正面和负面的 y[]
:
-1.27 -0.69 -0.56 -0.45 -0.23 0.07 0.13 0.46 1.56 1.72
这是我的新 b_slow[]
(这是地面实况,计算的天真方式):
1.20 0.92 1.00 1.01 0.79 0.53 0.56 0.53 1.33 1.49
但是现在,我的新 a_fast[]
不再匹配:
-1.20 -0.62 -0.49 -0.38 -0.16 -0.16 -0.10 0.23 1.33 1.49
这是我对 Francis 解决方案的实现(直到我们有两个排序数组,其中位数很容易计算)。我在 R 中这样做是为了保持问题的精神。
尽管如此,我似乎缺少索引的校正因子(下面代码中的 ww),所以下面的代码有时会稍微偏离一点。这是因为在上面的定义中,我们计算了 n-1 个观测值 (i!=j) 的中位数。
n<-100
y<-rnorm(n)
y<-sort(y)
b<-rep(NA,n)
#Naive --O(n**2)-- approch:
for(i in 1:n){
b[i]<-median(abs(y[-i]+y[i]))
}
k<-rep(NA,n)
i<-1
k[i]<-min(na.omit(c(which(y+y[i]>0)[1],n))) #binary search: O(log(n)) --
for(i in 2:n){ #O(n)
k_prov<-k[i-1]
while(y[k_prov]+y[i]>0 && k_prov>0) k_prov<-k_prov-1
k[i]<-max(k_prov+1,1)
#for(i in 1:n){ should give the same result.
# k[i]<-which(y+y[i]>0)[1]
#}
}
i<-sample(1:n,1)
x1<--y[1:(k[i]-1)]-y[i]
x2<-y[i]+y[n:k[i]]
x3<-c(x1,x2)
plot(x3)
ww<-ifelse(i<k[i] & i>n/2,n/2+1,n/2)
sort(x3)[ww] #this can be computed efficiently: O(log(n))
b[i] #this is the O(n**2) result.
最佳答案
这是一个 O(Nxln(N)xln(N)) 的解决方案:
对于所有的我:
1) 找到第k项,例如j<k <=> y[j]+y[i]<0
(二分法,O(ln(N)))
k 分隔两个排序列表:一个在 -y[i] 之上,另一个在 -y[i] 之下,应更改其符号以获得 abs(y[i]+y[j])。现在,我们正在寻找这些列表的中位数。
从这里看,就是finding the median of two sorted lists的问题了, 重复 n 次。
2)让我们选择这些列表中的最大值 (M=abs(y[1]-y[i]) 或 M=abs(y[size]-y[i])) 和最小值 (m around k)并重新开始二分法 (O(ln(N))。让我们从选择中间 (M+m)/2...开始...在任何阶段,让我们选择中间...
3)这个大二分法的阶段:第一个列表中有多少项 y[j]+y[i] 在 (M+m)/2 以上?再次二分法... O(ln(N))。在第二个列表中,有多少项 -y[j]-y[i] 在 (M+m)/2 以上?你猜怎么着 ?二分法...将这两个数字相加。如果大于(size-1)/2,则m=(M+m)/2。否则M=(M+m)/2。
4)如果m=M停止! b[i]=m;
我猜有人会提出更好的解决方案...
编辑:我应该感谢 @user189035 链接到 O(ln(n+m)) 算法来计算两个排序列表的中值。 How to find the kth smallest element in the union of two sorted arrays?
再见,
关于c++ - 计算排序数组的成对绝对和的中位数的高效算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23683440/
我想要做的是在每个框的蓝色标题之后获取红色文本。 看来我必须添加另一个 div?我已经添加并修改了 .card-indus img 的位置,但结果永远不是我想要的。 你知道为什么即使我将 positi
所以我一直在努力掌握绝对和相对定位的诀窍。关于这个主题有很多教程和问题,我已尽力理解它们。除了这一点,我大部分时间都很好。我正在创建一个页面,其中有较小的缩略图图像,用户可以选择单击并展开图像。为此,
下面是我正在处理的代码。如您所见,有一个“#parent”div 和一个“#child”div。 '#child' div 有一个未定义的高度,这是因为有时,'#child' 的高度小于或长于它的父级
我目前正在创建一个看起来有点像这样的固定 header 。 https://gyazo.com/e0bab8ba195e33110b19123c7fc3c568 Logo 始终位于左侧,小按钮始终位于
我怎样才能得到一个绝对定位的子 div,当它放在父 div 的范围之外时不显示? https://jsfiddle.net/knp9ebys/9/ .papa { background:red;
如果我对 CSS 显得相当“菜鸟”,我深表歉意。我一直在尝试设置以下... #0 { width: 100%; height: y; border: 1px solid black; } #
很长一段时间以来,我一直在摆弄一个特定的布局问题,但我显然采用了错误的方式。 以下是分解为基本组成部分的方法: SOME HEADER
我创建了几个虚拟 Controller ,我希望能够从当前的 http 请求中获取 url。 例如: http://www.site.com/app_1/default.aspx ===> http:
我创建了几个虚拟 Controller ,我希望能够从当前的 http 请求中获取 url。 例如: http://www.site.com/app_1/default.aspx ===> http:
我想知道是否有一个库在某处提供受新类型保护的 FilePath 类型。我找到了我想要的http://hackage.haskell.org/package/darcs-2.8.4/docs/src/D
如果我尝试使用以下方式连接到我的嵌入式数据库: private static String url = "jdbc:sqlite:~/hr4413/pkg/sqlite/Models_R_US.db"
所以我是 django 的新手,我一直在研究 PHP CodeIgniter,其中将绝对 URL 放入 href 我通过调用 URL 帮助程序使用了一个名为 base_url 的函数 它给出的输出类
我有一个小问题。 我在其他 div 中有一些图像元素的容器 div。像这样的东西: 我需要将容器垂直居中,但我不能使用顶部:-healfHeight; mar
我有一个带有 inline-block css 位置的列表(div)。里面有一个 relative 定位的 ul 是隐藏的。所以我试图通过添加一些类将这个 div 转换为 absolute 。通常,当
我正在尝试设置一个卡住列,唯一需要解决的问题是同一行上其他 td 的高度不会扩展以匹配绝对定位 td 的高度。由于卡住标题中的文本是任意的,它可以跨越多行。 如果它不是绝对定位的,那么这将迫使同一行中
这个问题在这里已经有了答案: Centering text vertically and horizontally in a div (1 个回答) 关闭 5 年前。
当它的位置绝对时,我试图使一个框宽度为 100%? 下图是我想要做的 https://i.imgur.com/qMaT361.gif float .box1 { position:re
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
我有 3 个 div,都是 positioned: absolute,但是我想要填充窗口宽度的 div 只会适应其中文本的长度。我希望黄色 div #help 填充窗口的其余部分。 我知道这听起来很菜
这个问题在这里已经有了答案: Retrieve the position (X,Y) of an HTML element (32 个答案) 关闭 8 年前。 有时候,当我请求某个对象的.posit
我是一名优秀的程序员,十分优秀!