如果String是’按字母顺序增长’,如何检入Scala?

前端之家收集整理的这篇文章主要介绍了如果String是’按字母顺序增长’,如何检入Scala?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
让我们在以下情况下定义String是“按字母顺序增长”:

>每个字母的字母大于前一个字母.
>如果字母大写,则无关紧要.

这些字符串按字母顺序增长:

>“abcde”
>“aBfJz”

而这些不是:

>“abbcd”
>“abdDz”
>“zba”

让我们假设我们正在检查只包含字母的字符串.
检查String是否“增长”可以在Scala中使用以下代码完成:

val str = "aBgjz"   
val growing = str.map(_.toLower).toSet.toList.sortWith( _ < _ ).mkString.equals(str.map(_.toLower))

代码效果很好,但仅适用于英文字母.对于带有波兰字母的字符串,结果是错误的.在波兰语字母中,字母按以下顺序排列:
a,±,b,c,ć,d,e ……
因此对于:

val str = "aąbćdgz"

结果应该是“真实的”.所以问题是:
如果给定的字符串按字母顺序增长,如何检查Scala?

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

猜你在找的Scala相关文章