class P(val a: Int, val b: Int)
val listp = List[P](new P(2,1))
listp.sortWith( (p1, p2) => p1.b < p2.b )
listp.sortBy(p => (p.b))
listp
很容易排序
val list = List((2, 1))
list.sortWith( (a1, b1), (a2, b2) => b1 < b2) // Too many arguements
list.sortWith( ((a1, b1), (a2, b2)) => b1 < b2) // Not a legal formal parameter / <error> is already defined as <error>
list.sortBy((a, b) => (b)) // wrong number of parameters expected
如何排序list
?列表的所有方法调用都会导致编译错误(我知道我忽略了返回值,我只关心语法)。
我只是在寻找匿名函数的语法。我知道可以在Java中继承Ordered
Comparable
。
编辑 - 感谢所有答案:
list.sortWith( _._2 < _._2)
list.sortBy(_._2)
list.sortWith( (t1, t2) => t1._2 < t2._2 )
这是明确的
list.sortWith( (t1: Tuple2[Int, Int], t2: Tuple2[Int, Int]) => t1._2 < t2._2 )
答案 0 :(得分:9)
鉴于
val list = List((2,1), (3,4))
按第二个元素排序:
list.sortBy(_._2)
或许多详细:
list.sortBy { case(a,b) => b }
答案 1 :(得分:5)
试试这个:
scala> val list = List((2, 1),(5,-10))
list: List[(Int, Int)] = List((2,1), (5,-10))
scala> list.sortWith{ case ((a1, b1), (a2, b2)) => b1 < b2}
res1: List[(Int, Int)] = List((5,-10), (2,1))
答案 2 :(得分:1)
val list = List((2,1), (3,4))
list.sort(_._1 < _._2)
res0: List[(Int, Int)] = List((2,1), (3,4))