欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Go語言如何實(shí)現(xiàn)字符串切片反轉(zhuǎn)函數(shù)

 更新時間:2022年10月19日 10:40:19   作者:宇宙之一粟  
Go?語言不像其他語言如?Python,有著內(nèi)置的?reverse()?函數(shù),本文將先學(xué)習(xí)一下Python中對于列表的反轉(zhuǎn)方法,然后再學(xué)習(xí)如果在Go語言中實(shí)現(xiàn)相同的功能,感興趣的小伙伴快跟隨小編一起來學(xué)習(xí)一下

Python 中的 reverse 函數(shù)

Go 語言不像其他語言如 Python,有著內(nèi)置的 reverse() 函數(shù),先來看一下 Python 中對于列表的反轉(zhuǎn)方法,然后我們再來學(xué)習(xí)如果在 Go 語言中實(shí)現(xiàn)相同的功能。

>>> myList = [2022, 2021, 2008, 2012]
>>> myList.reverse()
>>> print("Reversed List:", myList)
Reversed List: [2012, 2008, 2021, 2022]
>>> 

實(shí)現(xiàn)一個 reverse 反轉(zhuǎn)函數(shù)

reverse 算法取一個數(shù)據(jù)集,并將該數(shù)據(jù)集的值進(jìn)行反轉(zhuǎn),Go 標(biāo)準(zhǔn)的 sort 包并沒有內(nèi)置的方法來反轉(zhuǎn)一個切片。

利用兩個切片實(shí)現(xiàn)

設(shè)計思想:

  • 確定切片長度
  • 獲取最后一個元素
  • 以相反的順序在新切片中添加最后一個元素到第一個位置
package main

import "fmt"

func main() {
    s := []string{"hello", "foo", "bar", "go", "abc", "zzz"}

    // 定義新的反轉(zhuǎn)切片
    reverseOfS := []string{}

    // 遍歷原切片 s
    for i := range s {
        reverseOfS = append(reverseOfS, s[len(s)-1-i])
    }
    fmt.Println(reverseOfS)
}

運(yùn)行結(jié)果:

[zzz abc go bar foo hello]

顯然,這種方式會額外花費(fèi)一個相同空間的切片,空間復(fù)雜度為 O(n)。

前后兩兩原地交換

我們可以寫一個簡易的 reverse 函數(shù)來進(jìn)行數(shù)據(jù)的反轉(zhuǎn),通過循環(huán)原切片的一半,然后依次與對應(yīng)的元素進(jìn)行交換,比如::

func reverse(s []string) []string {
    for i := 0; i < len(s)/2; i++ {
        j := len(s) - i - 1
        s[i], s[j] = s[j], s[i]
    }
    return  s
}

這個函數(shù)可以通過更簡短的實(shí)現(xiàn),通過 Go 內(nèi)部的操作進(jìn)行循環(huán):

package main

import "fmt"

func reverse(s []string) []string {
    for i, j := 0, len(s)-1; i < j; i, j = i+1, j-1 {
        s[i], s[j] = s[j], s[i]
    }
    return s
}

func main() {
    s := []string{"hello", "foo", "bar", "go", "abc", "zzz"}

    reverseOfS := reverse(s)

    fmt.Println(reverseOfS)
}

執(zhí)行結(jié)果:

[zzz abc go bar foo hello]

但是,上面的 reverse 函數(shù)都是通過切片按值傳遞,其實(shí)我們在修改傳遞中的 []string 切片,實(shí)際上,可以通過以下方式進(jìn)一步簡寫:

package main

import "fmt"

func reverse(s []string) {
    for i := 0; i < len(s)/2; i++ {
        j := len(s) - i - 1
        s[i], s[j] = s[j], s[i]
    }
}

func main() {
    s := []string{"hello", "foo", "bar", "go", "abc", "zzz"}

    reverse(s)
    fmt.Printf("%v\n", s)
}

此時,reverse() 函數(shù)不會返回切片的另一個引用,此時的交換就是就地進(jìn)行,此時更像文章開頭 Python 中的 reverse() 函數(shù)。

反轉(zhuǎn)為原切片的副本

如果我們要返回切片的反轉(zhuǎn)的副本,reverse 函數(shù)就可以這樣寫:

package main

import "fmt"

func reverse(s []string) []string {

    newS := make([]string, len(s))
    for i, j := 0, len(s)-1; i <= j; i, j = i+1, j-1 {
        newS[i], newS[j] = s[j], s[i]
    }
    return newS
}

func main() {
    s := []string{"hello", "foo", "bar", "go", "abc", "zzz"}

    fmt.Printf("原字符串切片:%v\n", s)
    fmt.Printf("反轉(zhuǎn)后的切片:%v\n", reverse(s))
}

運(yùn)行結(jié)果:

原字符串切片:[hello foo bar go abc zzz]
反轉(zhuǎn)后的切片:[zzz abc go bar foo hello]

可以看到,原切片是沒有變化的。

當(dāng)然,因為我們沒有就地修改原切片,因此又可以回到最初的方法 append,看代碼:

func reverse(s []string) []string {

    newS := make([]string, 0, len(s))

    for i := len(s)-1; i >= 0; i-- {
        newS = append(newS, s[i])
    }
    return newS
}

運(yùn)行結(jié)果圖如下:

總結(jié)

本文通過 Python 中的 reverse() 函數(shù)的一個示例,引發(fā)出一個思考:Go 語言中有沒有類似的反轉(zhuǎn)函數(shù)?

然后通過幾種方式實(shí)現(xiàn)同樣的字符串切片的反轉(zhuǎn)功能,并通過借助額外空間和就地反轉(zhuǎn)兩種方式實(shí)現(xiàn)了功能相同 reverse 函數(shù),其實(shí)類似的反轉(zhuǎn)思想也可以用于字符串或者鏈表反轉(zhuǎn)等其他數(shù)據(jù)結(jié)構(gòu)。

到此這篇關(guān)于詳解Go語言如何實(shí)現(xiàn)字符串切片反轉(zhuǎn)函數(shù)的文章就介紹到這了,更多相關(guān)Go語言字符串切片反轉(zhuǎn)函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Go語言使用AES加密解密的示例代碼

    Go語言使用AES加密解密的示例代碼

    這篇文章主要介紹了Go語言使用AES加密解密的示例代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • Golang中errgroup的常見誤用詳解

    Golang中errgroup的常見誤用詳解

    errgroup和sync.WaitGroup類似,都可以發(fā)起執(zhí)行并等待一組協(xié)程直到所有協(xié)程運(yùn)行結(jié)束,本文主要為大家整理了一些errgroup的常見誤用,有需要的可以參考下
    2024-01-01
  • GO中Json解析的幾種方式

    GO中Json解析的幾種方式

    本文主要介紹了GO中Json解析的幾種方式,詳細(xì)的介紹了幾種方法,?文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • Beego中ORM操作各類數(shù)據(jù)庫連接方式詳細(xì)示例

    Beego中ORM操作各類數(shù)據(jù)庫連接方式詳細(xì)示例

    這篇文章主要為大家介紹了Beego中ORM操作各類數(shù)據(jù)庫連接方式詳細(xì)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • Windows下在CMD下執(zhí)行Go出現(xiàn)中文亂碼的解決方法

    Windows下在CMD下執(zhí)行Go出現(xiàn)中文亂碼的解決方法

    在cmd下運(yùn)行g(shù)o程序或者是GOLAND的Terminal下運(yùn)行g(shù)o程序會出現(xiàn)中文亂碼的情況。本文就詳細(xì)的介紹下解決方法,具有一定的參考價值,感興趣的可以了解一下
    2021-12-12
  • Go?Java算法之單詞搜索示例詳解

    Go?Java算法之單詞搜索示例詳解

    這篇文章主要為大家介紹了Go?Java算法之單詞搜索示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Golang通脈之流程控制詳情

    Golang通脈之流程控制詳情

    這篇文章主要介紹了Golang通脈之流程控制,流程控制是每種編程語言控制邏輯走向和執(zhí)行次序的重要部分,Go語言中最常用的流程控制有if和for,而switch和goto主要是為了簡化代碼,下面文章將詳細(xì)介紹改該內(nèi)容,需要的朋友可以參考一下
    2021-10-10
  • Go語言實(shí)現(xiàn)機(jī)器大小端判斷代碼分享

    Go語言實(shí)現(xiàn)機(jī)器大小端判斷代碼分享

    這篇文章主要介紹了Go語言實(shí)現(xiàn)機(jī)器大小端判斷代碼分享,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-10-10
  • Go到底能不能實(shí)現(xiàn)安全的雙檢鎖(推薦)

    Go到底能不能實(shí)現(xiàn)安全的雙檢鎖(推薦)

    這篇文章主要介紹了Go到底能不能實(shí)現(xiàn)安全的雙檢鎖,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • 一文詳細(xì)介紹golang中.()類型斷言的使用方法

    一文詳細(xì)介紹golang中.()類型斷言的使用方法

    Golang是一門非常流行的編程語言,在很多領(lǐng)域都有著廣泛的應(yīng)用,在開發(fā)過程中,很多時候我們需要將函數(shù)作為參數(shù)傳遞給其他函數(shù),這時候就需要用到golang中的.()用法,本文將詳細(xì)介紹golang中.()的使用方法,需要的朋友可以參考下
    2023-08-08

最新評論