例如

需要注意的点

分析

代码

	//字符串翻转
	fileprivate func charReverse<T>(_ chars: inout [T], _ start: Int, _ end: Int) {
      	var s = start, e = end
        while s < e {
            swap(&s, &e)
            s += 1
            e -= 1
        }
    }
    //单词顺序进行反转
   	func wordReverse(s: String?) -> String? {
        guard let s = s else {
            return nil
        }
        var chars = Array(s), start = 0
        charReverse(&chars, 0, chars.count - 1)
        for i in 0..<chars.count {
            if i == chars.count - 1 || chars[i + 1] == " " {
                charReverse(&amp;chars, start, i)
                start = i + 2
            }
        }
        return String(chars)
    }

总结

时间复杂度 O(n)。

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注