本文主要是介绍Golang leetcode151 翻转字符串中的单词 双指针 常规+进阶,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
翻转字符串中的单词 leetcode151
常规做法 双指针
func reverseWords(s string) string {
WordList := []string{}
left := 0
L := len(s)
//fmt.Println(L)for i, i2 := range s {//去除重复的空格if i > 0 && s[i-1] == ' ' && i2 == ' ' {left++continue}//不为空格时右指针移动,并且如果最后一位也为字母时添加到存储表if i2 != ' ' {if i == L-1 {WordList = append(WordList, s[left:i+1])}} else { //当为空格时,将当前的左右指针对应的单词放入存储表,同时给左指针赋值if i != 0 {WordList = append(WordList, s[left:i])}left = i + 1}}S := WordList[0]for i, s2 := range WordList {if i != 0 {S = s2 + " " + S}}return S
}
进阶做法 空间复杂度O(1)
解题思路如下:
- 移除多余空格
- 将整个字符串反转
- 将每个单词反转
func reverseWords(s string) string {// 1.去除字符串中多余的空格b := []byte(s) //将字符串转换为字符切片slow, l := 0, len(b)for fast := 0; fast < l; fast++ {if b[fast] != ' ' { //直接让fast指针移动到第一个字母的位置if slow != 0 { //排除字符串开头的空格b[slow] = ' ' //保留单词间的空格slow++}for fast < l && b[fast] != ' ' {b[slow] = b[fast]slow++fast++}}}b = b[:slow] //取slow之前的字符串// 2.反转整体字符串reverse(b)// 3.反转每个单词last := 0 //慢指针l = len(b)for i := 0; i <= l; i++ { //注意这里是i<=lif i == l || b[i] == ' ' { //当i等于字符串长度或者值为空,i==l必须写在前面因为b[l]不存在会报错reverse(b[last:i]) //反转每个单词,左闭右开last = i + 1}}return string(b) //将字符切片转换为字符串
}
func reverse(s []byte) {
L := len(s)
//双指针
left, right := 0, L-1for left < right {
s[left], s[right] = s[right], s[left]
left++
right--
}
}
这篇关于Golang leetcode151 翻转字符串中的单词 双指针 常规+进阶的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!