344. Reverse String

/**
 Write a function that takes a string as input and returns the string reversed.

Example:
Given s = "hello", return "olleh".

Subscribe to see which companies asked this question
*/

/*
 Thinking:
 这个比较简单,只需要一左一右交换,知道相遇就可以了
 */

func reverseString(_ s: String) -> String {
    guard s.lengthOfBytes(using: .ascii) > 1 else {
        return s
    }
    
    var array = s.characters.map { String($0) }
    
    func swapArray(_ left: Int, _ right: Int) {
        if (left != right) {
            swap(&array[left], &array[right])
        }
    }
    
    var left = 0
    var right = array.count - 1
    while left < right {
        swapArray(left, right)
        left += 1
        right -= 1
    }
    
    return array.joined()
}

reverseString("a")
reverseString("ab")
reverseString("acddeasfaf")
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容