登录
首页 >  Golang >  Go问答

如何在 Golang 中编写函数来仅使用 1 个分配/操作来反转 unicode 字符串?

来源:stackoverflow

时间:2024-02-10 11:54:39 285浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《如何在 Golang 中编写函数来仅使用 1 个分配/操作来反转 unicode 字符串?》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

问题内容

我需要为 unicode 字符串编写自己的 reverse.Reverse 模拟。这是我的代码:

func Reverse(input string) string {
    runes := []rune(input)

    var result strings.Builder
    result.Grow(len(runes))

    for i := len(runes) - 1; i >= 0; i-- {
        result.WriteRune(runes[i])
    }

    return result.String()
}

但它会产生 2 个分配/操作:

cpu: 11th Gen Intel(R) Core(TM) i7-11850H @ 2.50GHz
BenchmarkReverse
BenchmarkReverse-16       297900              7014 ns/op            1792 B/op          2 allocs/op

如何只进行 1 次分配/操作?我知道,这是可能的

而且我也不明白为什么 result.Grow(len(runes)) 使 5 个分配/操作和 result.Grow(len(input)) - 1 个分配/操作


正确答案


创建具有所需容量的 strings.Builder。以相反的顺序将源字符串中的符文写入构建器。

func Reverse(str string) string {
    var result strings.Builder
    result.Grow(len(str))
    for len(str) > 0 {
        r, size := utf8.DecodeLastRuneInString(str)
        result.WriteRune(r)
        str = str[:len(str)-size]
    }
    return result.String()
}

https://go.dev/play/p/PNGmFcSTo8q

这个答案复制了问题中的功能。我并不认为结果以字形显示给人类是有意义的。例如,组合字符不会像原始字符串那样组合。

下面是一个人为示例,说明了反向函数的用途:应用程序的某些值集的字符串键往往具有常见的前缀和不常见的后缀。应用程序可以通过反转密钥来改善字符串空间的分布。

终于介绍完啦!小伙伴们,这篇关于《如何在 Golang 中编写函数来仅使用 1 个分配/操作来反转 unicode 字符串?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>