题解 | #句子逆序#

句子逆序

https://www.nowcoder.com/practice/48b3cb4e3c694d9da5526e6255bb73c3

package main

import (
	"fmt"
	"os"
    "bufio"
)

func reverse(sb []byte, left int, right int) {
    // 对 sb[left, right] 区间进行反转,左闭右闭区间
    for i,j := left,right; i<j; i,j = i+1,j-1 {
        sb[i], sb[j] = sb[j], sb[i]
    }
}

func generateReverseSentence(s string) string {
    sb := []byte(s)
    size := len(sb)
    
    // 整体反转
    reverse(sb, 0, size-1)

    // 对每个单词进行反转
    slow, fast := 0, 0
    for fast < size {
        for fast < size && sb[fast] != ' ' {
            fast++
        }
        reverse(sb, slow, fast-1)
        slow = fast + 1
        fast = slow
    }

    return string(sb)
}

func main() {
    var s string

    inputReader := bufio.NewReader(os.Stdin)
    data, _, _ := inputReader.ReadLine()
    s = string(data)

    fmt.Println(generateReverseSentence(s))
}
// 本题为输入一个字符串,所以采用标准处理:inputReader.ReadLine()

全部评论

相关推荐

快手真的是我目前面试到的最有压力的了,全程一个多小时,不断的问我简历上的项目,以及当时的做法想法思路,问到我答不出来为止,我就很难判断我的回答是不是他想要听到的,非常折磨。。。。
在吵架的熊熊很甜美:我昨晚面阿里巴巴某事业群的时候一模一样。他揪着问很细很细的点,我只能按照自己的想法回答,他一点点反馈都没有,我不知道说的对不对,越说越心虚,我说不下去之后,他居然在那笑…好讨厌这样的面试…
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务