成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

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

?1.Python 中的 reverse 函數(shù)

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

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

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

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

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

設(shè)計(jì)思想:

  • 確定切片長(zhǎng)度
  • 獲取最后一個(gè)元素
  • 以相反的順序在新切片中添加最后一個(gè)元素到第一個(gè)位置
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]

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

3前后兩兩原地交換

我們可以寫一個(gè)簡(jiǎn)易的 reverse 函數(shù)來進(jìn)行數(shù)據(jù)的反轉(zhuǎn),通過循環(huán)原切片發(fā)熱一半,然后依次與對(duì)應(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
}

這個(gè)函數(shù)可以通過更簡(jiǎn)短的實(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í)我們?cè)谛薷膫鬟f中的 []string 切片,實(shí)際上,可以通過以下方式進(jìn)一步簡(jiǎ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)
}

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

4.反轉(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)然,因?yàn)槲覀儧]有就地修改原切片,因此又可以回到最初的方法 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é)果圖如下:

圖片

5.總結(jié)

本文通過 Python 中的 reverse() 函數(shù)的一個(gè)示例,引發(fā)出一個(gè)思考: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)。

責(zé)任編輯:武曉燕 來源: 宇宙之一粟
相關(guān)推薦

2009-08-11 10:26:49

C#算法C#字符串反轉(zhuǎn)

2023-12-11 07:33:05

Go語言字符技巧

2011-07-15 11:07:41

C語言字符串函數(shù)

2011-07-15 12:41:53

C語言

2023-04-03 08:02:16

切片擴(kuò)容GO

2021-10-14 15:34:48

C語言字符串函數(shù)

2010-05-26 15:14:39

MySQL字符串

2010-05-26 15:36:23

MySQL字符串

2014-01-02 16:14:10

PostgreSQL字符串

2021-05-24 10:24:42

Golang字符串Python

2019-12-25 15:41:50

JavaScript程序員編程語言

2023-05-29 08:03:41

代碼Go語言

2010-10-09 11:54:46

MySQL字符串

2022-04-06 08:19:13

Go語言切片

2023-03-29 08:03:53

2011-03-15 15:20:46

2021-09-10 08:18:31

Go語言字符串

2021-03-08 08:57:00

Go 字符串測(cè)試

2010-09-09 11:48:00

SQL函數(shù)字符串

2009-08-06 16:01:09

C#字符串函數(shù)大全
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 中文字幕一区在线观看视频 | 精品91视频 | 黄色毛片黄色毛片 | 香蕉大人久久国产成人av | 日韩视频 中文字幕 | 国产成人精品999在线观看 | 久久www免费视频 | 久久国产日韩欧美 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 亚洲精品www久久久久久广东 | 狠狠色香婷婷久久亚洲精品 | 日本一区二区三区四区 | 久久久久久黄 | 好姑娘影视在线观看高清 | 天天久久 | 国产精品视频999 | 国产一区二区三区 | 免费欧美| 日韩电影一区 | 日韩成人av在线播放 | 亚洲第一av | 瑟瑟免费视频 | www.日韩系列 | 成人欧美一区二区三区1314 | 国产一级特黄视频 | 狠狠插狠狠操 | 在线观看欧美一区 | 婷婷在线视频 | 精品av久久久久电影 | 一区在线免费视频 | 超碰免费在线观看 | 观看毛片| 国产乱码一区 | a黄视频| 中文字幕在线视频一区二区三区 | 日韩在线不卡 | 国产成人精品一区二区三区视频 | 中文字幕一区二区三区四区 | 精品欧美一区二区三区久久久小说 | 精品在线免费观看视频 | 天天做日日做 |