В Python я могу сделать:
in_dd = {"aaa": 1, "bbb": 7, "zzz": 3, "hhh": 9, "ggg": 10, "ccc": 3}
out_ll = ['ggg', 'hhh', 'bbb', 'aaa', 'ccc', 'zzz']
Итак, я хочу получить ключи, отсортированные по значению в порядке убывания, имея ключи в порядке возрастания с учетом отсортированных значений.
Как я могу сделать это в Scala?
В Scala я знаю, что могу:
val m = Map("aaa" -> 3, "bbb" -> 7, "zzz" -> 3, "hhh" -> 9, "ggg" -> 10, "ccc" -> 3)
m.toSeq.sortWith(_._2 > _._2)
но я не знаю, как сортировать по двум случаям.
Обновлено:
Я пробовал и такой подход, но он не возвращает желаемого результата:
m.toSeq.sortWith((x,y) => x._2 > y._2 && x._1 < y._1).map(_.1)
List((ggg,10), (hhh,9), (bbb,7), (ccc,3), (zzz,3), (aaa,3))
обратите внимание, что это должно быть aaa, ccc, zzz
В scala вы можете использовать:
m.toSeq.sortBy(a => (a._2, a._1) )(Ordering.Tuple2(Ordering.Int.reverse, Ordering.String.reverse))
для List((ggg,10), (hhh,9), (bbb,7), (zzz,3), (ccc,3), (aaa,3))
и
m.toSeq.sortBy(a => (-a._2, a._1) )
для List((ggg,10), (hhh,9), (bbb,7), (aaa,3), (ccc,3), (zzz,3))
@DariuszKrynicki См. редактирование для изменения порядка.
m.toSeq.sortBy(a => (a._2, a._1))(Ordering.Tuple2(Ordering.Int.reverse, Ordering.String)) << ЭТО ДЕЛАЕТ РАБОТУ ДЛЯ МЕНЯ. СПАСИБО