您的位置:首页 > 其它

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

2017-09-21 05:50 190 查看
问题:如何判断一个字符串儿是否是回文?
  所谓的字符串儿回文,就是无论是正序读还是反序读,它都是一毛一样的,比如说字符串儿“rotator”,无论是从左往右读,还是从右往左读,它都是同一个字符串儿。

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

func challenge(input: String) -> Bool {

return input.characters.reversed() == Array(input.characters)
}

challenge(input: "rotator")  // 应该返回true
challenge(input: "Hello, world")  // 应该返回false
challenge(input: "Rotator")  // 应该返回true

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



程序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")

  转换完成之后就不会有问题了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: