判断一个字符串是否是回文

来源:互联网 发布:广西网络电视台 编辑:程序博客网 时间:2024/06/05 14:19
问题:如何判断一个字符串儿是否是回文?

  所谓的字符串儿回文,就是无论是正序读还是反序读,它都是一毛一样的,比如说字符串儿“rotator”,无论是从左往右读,还是从右往左读,它都是同一个字符串儿。

  思路:因为回文是正着读和反着读是一样的,所以我们马上就想到了reversed()函数。而这个函数的返回值是一个数组,因此最后肯定会用到数组的比较。好在数组属于集合,是值类型,比较起来就容易多了:

func challenge(input: String) -> Bool {        return input.characters.reversed() == Array(input.characters)}challenge(input: "rotator")  // 应该返回truechallenge(input: "Hello, world")  // 应该返回falsechallenge(input: "Rotator")  // 应该返回true

  上面的代码看起来是符合题目的要求了,但是实际上它还有一个bug,因为字母是分大小写的。如果将本来符合题目要求的字符串儿换成大小写混合的形式,那么它的结果就不符合题目要求:

程序bug.png
程序bug.png

  解决这个bug也非常的容易,就是在比较上面这两个数组之前,先将输入的字符串儿统一转换成大写或者小写:

func challenge1(input: String) -> Bool {        // 先将输入的字符串儿转换成大写或者小写    let lowercase = input.lowercased()        return lowercase.characters.reversed() == Array(lowercase.characters)}challenge1(input: "rotator")challenge1(input: "Hellow, world")challenge1(input: "Rotator")

  转换完成之后就不会有问题了。

原创粉丝点击