如果String是’按字母顺序增长’,如何检入Scala?
发布时间:2020-12-16 18:05:24 所属栏目:安全 来源:网络整理
导读:让我们在以下情况下定义String是“按字母顺序增长”: 每个字母的字母大于前一个字母. 如果字母大写,则无关紧要. 这些字符串按字母顺序增长: “abcde” “aBfJz” 而这些不是: “abbcd” “abdDz” “zba” 让我们假设我们正在检查只包含字母的字符串. 检
让我们在以下情况下定义String是“按字母顺序增长”:
>每个字母的字母大于前一个字母. 这些字符串按字母顺序增长: >“abcde” 而这些不是: >“abbcd” 让我们假设我们正在检查只包含字母的字符串. val str = "aBgjz" val growing = str.map(_.toLower).toSet.toList.sortWith( _ < _ ).mkString.equals(str.map(_.toLower)) 此代码效果很好,但仅适用于英文字母.对于带有波兰字母的字符串,结果是错误的.在波兰语字母中,字母按以下顺序排列: val str = "a?b?dgz" 结果应该是“真实的”.所以问题是: val str = "a?b?dgz" val locale_id = "pl_PL" .... val growing = ...... 解决方法scala> import java.util.Locale scala> import java.text.Collator scala> val collator = Collator.getInstance(new Locale("pl_PL")) scala> val str = "a?b?dgz" str: String = a?b?dgz scala> str.map(_.toLower).toSet.toList.sortWith( (s1:Char,s2:Char) => collator.compare(s1.toString,s2.toString) < 0 ).mkString.equals(str.map(_.toLower)) res06: Boolean = true 虽然我觉得这更容易阅读: scala> (str,str.tail).zipped.forall { case (s1,s2) => collator.compare(s1.toString,s2.toString) < 0 } res08: Boolean = true (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |