例如

需要注意的点

分析

代码

	//字符串翻转
	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)。

原文地址:https://blog.csdn.net/callauxiliary/article/details/116573616

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_31454.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

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