Go語言標(biāo)準(zhǔn)庫中提供了sort包對整型,浮點(diǎn)型,字符串型切片進(jìn)行排序,檢查一個(gè)切片是否排好序,使用二分法搜索函數(shù)在一個(gè)有序切片中搜索一個(gè)元素等功能。
成都創(chuàng)新互聯(lián)公司于2013年成立,先為左權(quán)等服務(wù)建站,左權(quán)等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為左權(quán)企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
關(guān)于sort包內(nèi)的函數(shù)說明與使用,請查看
在這里簡單講幾個(gè)sort包中常用的函數(shù)
在Go語言中,對字符串的排序都是按照字節(jié)排序,也就是說在對字符串排序時(shí)是區(qū)分大小寫的。
二分搜索算法
Go語言中提供了一個(gè)使用二分搜索算法的sort.Search(size,fn)方法:每次只需要比較㏒?n個(gè)元素,其中n為切片中元素的總數(shù)。
sort.Search(size,fn)函數(shù)接受兩個(gè)參數(shù):所處理的切片的長度和一個(gè)將目標(biāo)元素與有序切片的元素相比較的函數(shù),該函數(shù)是一個(gè)閉包,如果該有序切片是升序排列,那么在判斷時(shí)使用 有序切片的元素 = 目標(biāo)元素。該函數(shù)返回一個(gè)int值,表示與目標(biāo)元素相同的切片元素的索引。
在切片中查找出某個(gè)與目標(biāo)字符串相同的元素索引
選擇排序提高了冒泡排序的性能,它每遍歷一次列表只交換一次數(shù)據(jù),即進(jìn)行一次遍歷時(shí)找 到最大的項(xiàng),完成遍歷后,再把它換到正確的位置。和冒泡排序一樣,第一次遍歷后,最大的數(shù) 據(jù)項(xiàng)就已歸位,第二次遍歷使次大項(xiàng)歸位。這個(gè)過程持續(xù)進(jìn)行,一共需要 n-1 次遍歷來排好 n 個(gè)數(shù) 據(jù),因?yàn)樽詈笠粋€(gè)數(shù)據(jù)必須在第 n-1 次遍歷之后才能歸位。
golang語言map的并發(fā)和排序
golang缺省的map不是thread safe的,如果存在讀寫并發(fā)的使用場景,必須在外面使用lock機(jī)制。
包sync里面引入一個(gè)安全map;
用法:
運(yùn)行結(jié)果如下:
golang官方說法map并不排序,不按key排序,也不按插入順序排序,也就是說map是無序的,無法保證任何排序。
下面是一種常見的給map排序輸出的辦法:
如果是只有這幾個(gè)的話 我們可以考慮自定義一個(gè)排序類型
func TestSort(t *testing.T) {
data := []string{"三級", "一級", "二級"}
rule := map[string]int{
"一級": 1,
"二級": 2,
"三級": 3,
}
self := SelfSort{
Rule: rule,
Data: data,
}
sort.Sort(self)
fmt.Println(self.Data)
}
type SelfSort struct {
Rule map[string]int
Data []string
}
func (p SelfSort) Len() int? ? ? ? ? ?{ return len(p.Data) }
func (p SelfSort) Less(i, j int) bool { return p.Rule[p.Data[i]] p.Rule[p.Data[j]] }
func (p SelfSort) Swap(i, j int)? ? ? { p.Data[i], p.Data[j] = p.Data[j], p.Data[i] }
如過很多 就是真的要比較中文的話, 就用這種
package mainimport ( ? ?"bytes"
"fmt"
"io/ioutil"
"sort"
"golang.org/x/text/encoding/simplifiedchinese"
"golang.org/x/text/transform")//ByPinyin is customized sort interface to sort string by Chinese PinYintype ByPinyin []stringfunc (s ByPinyin) Len() int ? ? ?{ return len(s) }func (s ByPinyin) Swap(i, j int) { s[i], s[j] = s[j], s[i] }func (s ByPinyin) Less(i, j int) bool {
a, _ := UTF82GBK(s[i])
b, _ := UTF82GBK(s[j])
bLen := len(b) ? ?for idx, chr := range a { ? ? ? ?if idx bLen-1 { ? ? ? ? ? ?return false
} ? ? ? ?if chr != b[idx] { ? ? ? ? ? ?return chr b[idx]
}
} ? ?return true}//UTF82GBK : transform UTF8 rune into GBK byte arrayfunc UTF82GBK(src string) ([]byte, error) {
GB18030 := simplifiedchinese.All[0] ? ?return ioutil.ReadAll(transform.NewReader(bytes.NewReader([]byte(src)), GB18030.NewEncoder()))
}//GBK2UTF8 : transform ?GBK byte array into UTF8 stringfunc GBK2UTF8(src []byte) (string, error) {
GB18030 := simplifiedchinese.All[0]
bytes, err := ioutil.ReadAll(transform.NewReader(bytes.NewReader(src), GB18030.NewDecoder())) ? ?return string(bytes), err
}func main() {
b := []string{"哈", "呼", "嚯", "ha", ","}
sort.Strings(b) ? ?//output: [, ha 呼 哈 嚯]
fmt.Println("Default sort: ", b)
sort.Sort(ByPinyin(b)) ? ?//output: [, ha 哈 呼 嚯]
fmt.Println("By Pinyin sort: ", b)
}
copy from?網(wǎng)頁鏈接
分享題目:go語言中結(jié)構(gòu)圖排序 go語言的數(shù)據(jù)結(jié)構(gòu)
網(wǎng)站路徑:http://jinyejixie.com/article46/dosgheg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、網(wǎng)站內(nèi)鏈、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站設(shè)計(jì)、做網(wǎng)站、
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)