我有一个对象列表A(alist).
A {
val b : Int
val c1 : Int
val c2 : Int
val d1 : Int
val d2 : Int
}
Run Code Online (Sandbox Code Playgroud)
我想他们组b和计算的总和c1+c2,并d1+d2在每个组,并把结果在电子商务的对象名单elist.
E {
val sum_of_c_types : Int
val sum_of_d_types : Int
}
Run Code Online (Sandbox Code Playgroud)
如何使用任何集合内置函数在kotlin中实现?
注意:
我知道我可以用reduce函数来创建临时的A对象,但这对于在代码中不使用临时A对象很重要.
我用的序列解决了它groupBy,map和sumBy.这可能不是我猜的最干净的解决方案.
data class A(val b: Int,
val c1: Int,
val c2: Int,
val d1: Int,
val d2: Int)
data class E(val sumC: Int, val sumD: Int)
fun main(args: Array<String>) {
val alist = listOf(A(1, 2, 1, 4, 5), A(1, 3, 4, 6, 3), A(2, 2, 2, 2, 2), A(3, 1, 2, 1, 2))
val grouped: Map<Int, E> = alist.groupBy(A::b).mapValues {
E(it.value.sumBy { it.c1 + it.c2 }, it.value.sumBy { it.d1 + it.d2 })
}
grouped.forEach {
println("Group b=${it.key}: ${it.value}")
}
}
Run Code Online (Sandbox Code Playgroud)
结果是:
Group b=1: E(sumC=10, sumD=18)
Group b=2: E(sumC=4, sumD=4)
Group b=3: E(sumC=3, sumD=3)
Run Code Online (Sandbox Code Playgroud)
编辑:
使用Grouping(groupingBy代替groupBy),它看起来更好,因为您不必处理地图实体:
val grouped = alist.groupingBy(A::b).aggregate { _, acc: E?, e, _ ->
E((acc?.sumC ?: 0) + e.c1 + e.c2, (acc?.sumD ?: 0) + e.d1 + e.d2)
}
Run Code Online (Sandbox Code Playgroud)
I think it's just grouping with folding
fun group(a: List<A>) = a.groupingBy(A::b).fold(E(0, 0),
{ acc, elem ->
E(acc.sum_of_c_types + elem.c1 + elem.c2,
acc.sum_of_d_types + elem.d1 + elem.d2)
})
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3050 次 |
| 最近记录: |