从一个数组获取索引并更新第二个数组中相同索引的元素

Get indexes from one array and update elements on same indexes in second array

我有两个数组,上限和下限。

val solution : Array[Double] = Array(1.0, 33.0, 31.0, 82.0, 51.0, 25.0, 39.0, 96.0, 95.0, 49.0)
val original : Array[Double] = Array(3.0, 45.0, 18.0, 25.0, 99.0, 6.0, 36.0, 61.0, 82.0, 62.0)
val lower = 30
val upper = 90

布尔类型的数组是使用解决方案数组创建的。

val idx_lowest : Array[Boolean]  = solution.map ( x => x < lower )
idx_lowest: Array[Boolean] = Array(true, false, false, false, false, true, false, false, false, false)

idx_lowest 中查找值为 true 的索引

val trueIndexes = idx_lowest .zipWithIndex filter(x => x._1  ) map(_._2)
trueIndexes: Array[Int] = Array(0, 5)

根据 trueIndexesoriginal 数组中查找值。

val tmp = trueIndexes map original
Array[Double] = Array(3.0, 6.0)

tmp 数组的元素执行操作。

val tmp1 = tmp  map (x => (x+lower)/2.0)
Array[Double] = Array(16.5, 18.0)

更新解决方案数组的元素。索引由 trueIndexes 指定。小于 下限 的元素被更新。

for(i <- tmp1.indices)  {
    solution(trueIndexes(i)) = tmp1(i)
  }

更新后的解数组为:

Array[Double] = Array(16.5, 33.0, 31.0, 82.0, 51.0, 18.0, 39.0, 96.0, 95.0, 49.0)

必须执行相同的步骤来更新大于 upper 界限的元素。这是代码。

val idx_false : Array[Boolean]  = solution.map ( x => x > upper )
val falseIndexes = idx_false .zipWithIndex filter(x => x._1  ) map(_._2)
val tmp2 = falseIndexes map original 
val tmp3 = tmp2 map (x => (x+upper)/2.0)
for(i <- tmp3.indices)  {
   solution(falseIndexes(i)) = tmp3(i)
}
solution

此代码完全符合我的需要,但必须执行大量操作。在迭代算法中,我必须在每个数组的每次迭代中执行这些操作。是否有更高效、最优和更快的方法来执行相同的操作?

您可以 zip 它们并在一次操作中进行映射:

solution.zip(original)
  .map { case(s, o) => if(s < lower) ((o + lower) / 2, o) else (s, o) }
  .map { case(s, o) => if(s > upper) (o + upper) / 2 else s }

这不是一样的结果吗?

val done = solution.indices.map{x =>
  if (solution(x) < lower)      (lower + original(x))/2.0
  else if (solution(x) > upper) (upper + original(x))/2.0
  else solution(x)
}.toArray