4

我是 Scala Collections 的新手,目前我想将给定的字符串列表分成两个列表的元组(List[String], List[String]),其中包含回文字符串列表和其余输入字符串。

例如,如果输入是List("racecar", "abcd", "lilil", "effg") 输出应该是(List("racecar", "lilil"), List("abcd", "effg"))

我有一个使用过滤器的解决方案。但是,目前,尝试使用 foldLeft 改进我的解决方案。我的新方法如下:

def stringTuples2(strings: List[String]): (List[String], List[String]) = {
strings.foldLeft((List[String](), List[String]()))((b, a) => {
  if (a.equals(a.reverse)) { b._1 :+ a; b }
  else { b._2 :+ a; b }
})}

我不确定,我做错了什么,但这个解决方案的输出是两个空列表的元组,即(List(),List())。

帮助表示赞赏。谢谢!

4

1 回答 1

8

您尝试修改b会创建一个新的List,然后您将新的List扔掉并返回b,它没有改变。取出;b部分并返回更新后的元组:(b._1 :+ a, b._2)(b._1, b._2 :+ a)

顺便说一句,这是解决方案的不同方法。

List("racecar", "abcd", "lilil", "effg").partition(s => s == s.reverse)
于 2017-06-29T05:14:35.443 回答