美文网首页
判断一个字符串是否是回文

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

作者: 落叶刺客 | 来源:发表于2017-07-31 16:22 被阅读7次
    问题:如何判断一个字符串儿是否是回文?

      所谓的字符串儿回文,就是无论是正序读还是反序读,它都是一毛一样的,比如说字符串儿“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")
    

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

    相关文章

      网友评论

          本文标题:判断一个字符串是否是回文

          本文链接:https://www.haomeiwen.com/subject/zomqlxtx.html