[英]Compare each element of Scala list against rest of elements in the list
我有一个Custom对象列表,它将与同一列表中的其余对象进行比较。
我目前的方法:目前我使用foreach循环从列表中获取一个元素,运行另一个foreach循环以查看列表中与被摄对象类似的元素。
case class TestOb(name:String,pos:Vector[Int])
val lis:List[TestOb] = null
lis.foreach{i=>
val ref = i._2
lis.foreach{j=>
val current = j._2
//compare ref and current.
}
}
有没有其他有效的方法在Scala中在同一列表中进行此迭代而没有两个foreach循环?
你尝试过使用for
-loop吗?
for( a <- lis; b <- lis) {
// do stuff with a and b
}
为了进一步方便,这里有一个简单的例子来了解幕后的迭代:
scala> val list = 1 to 3
list: scala.collection.immutable.Range.Inclusive = Range(1, 2, 3)
scala> for(a <- list; b <- list) println(a+" - "+b)
1 - 1
1 - 2
1 - 3
2 - 1
2 - 2
2 - 3
3 - 1
3 - 2
3 - 3
对于它的价值,酶解决方案将更符合功能风格的scala包容。
一种方法,用于比较集合中的每个元素与其余元素,并收集相似的元素(这里使用==
在collect
相同)。 为了说明案例的考虑
case class C(i:Int)
和一个集合,其中C(1)
有一个similar
项目(这里相等),
val xs = Array( C(1),C(2),C(3),C(1),C(4) )
因此,我们将每两项合并,比较它们并收集相似的项目,
xs.combinations(2).collect { case Array(a,b) if a == b => a }.toArray
Array(C(1))
注意combinations
提供了一个迭代器,它由collect
消耗(迭代)。 另外,在collect
使用不相似函数替换==
来比较项目以确定哪些足够相似。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.