網(wǎng)站首頁 編程語言 正文
說在前面
- go version:go1.14.1 windows/amd64
實(shí)現(xiàn)
- 借助
golang
中的sort
包可以方便的使用二分查找。func Search(n int, f func(int) bool) int { // Define f(-1) == false and f(n) == true. // Invariant: f(i-1) == false, f(j) == true. i, j := 0, n for i < j { h := int(uint(i+j) >> 1) // avoid overflow when computing h // i ≤ h < j if !f(h) { i = h + 1 // preserves f(i-1) == false } else { j = h // preserves f(j) == true } } // i == j, f(i-1) == false, and f(j) (= f(i)) == true => answer is i. return i }
- 借助二分查找可以方便的實(shí)現(xiàn)有序列表。
代碼
-
例如有序的
uint64
切片func SeachUint64List(arr []uint64, x uint64) int { return sort.Search(len(arr), func(i int) bool { return arr[i] >= x }) } func InsertOrderedUint64List(arr []uint64, x uint64) []uint64 { i := SeachUint64List(arr, x) arr = append(arr, 0) copy(arr[i+1:], arr[i:]) arr[i] = x return arr } func main() { var arr []uint64 arr = InsertOrderedUint64List(arr, 12) arr = InsertOrderedUint64List(arr, 2) arr = InsertOrderedUint64List(arr, 102) arr = InsertOrderedUint64List(arr, 1) arr = InsertOrderedUint64List(arr, 14542) arr = InsertOrderedUint64List(arr, 112) arr = InsertOrderedUint64List(arr, 142) fmt.Println(arr) // [1 2 12 102 112 142 14542] }
-
其他的可以通過定義結(jié)構(gòu)體,并使用
Key
進(jìn)行排序,例如type Node struct { Key uint64 Value string } func SeachNodeList(arr []*Node, x uint64) int { return sort.Search(len(arr), func(i int) bool { return arr[i].Key >= x }) } func InsertOrderedNodeList(arr []*Node, x *Node) []*Node { if x == nil { return arr } i := SeachNodeList(arr, x.Key) arr = append(arr, &Node{}) copy(arr[i+1:], arr[i:]) arr[i] = x return arr } func main() { var arr []*Node arr = InsertOrderedNodeList(arr, &Node{Key: 12, Value: "ha"}) arr = InsertOrderedNodeList(arr, &Node{Key: 1432, Value: "ta"}) arr = InsertOrderedNodeList(arr, &Node{Key: 112, Value: "see"}) arr = InsertOrderedNodeList(arr, &Node{Key: 1452, Value: "sight"}) arr = InsertOrderedNodeList(arr, &Node{Key: 13332, Value: "peer"}) arr = InsertOrderedNodeList(arr, &Node{Key: 12, Value: "one"}) arr = InsertOrderedNodeList(arr, &Node{Key: 2, Value: "kiss"}) for _, node := range arr { fmt.Println(*node) } // {2 kiss} // {12 one} // {12 ha} // {112 see} // {1432 ta} // {1452 sight} // {13332 peer} }
-
其他還可以進(jìn)一步進(jìn)行封裝,例如寫成
package
原文鏈接:https://blog.csdn.net/qq_33446100/article/details/123434855
相關(guān)推薦
- 2023-02-23 Python創(chuàng)建7種不同的文件格式的方法總結(jié)_python
- 2022-10-08 C#中的timer與線程使用_C#教程
- 2023-07-10 Spring MVC 詳解(連接、獲取參數(shù)、返回?cái)?shù)據(jù))
- 2022-06-02 JQuery實(shí)現(xiàn)動態(tài)漂浮廣告_jquery
- 2022-02-03 Gogs clone倉庫地址為localhost
- 2023-01-18 Python中的函數(shù)參數(shù)類型檢查_python
- 2024-04-23 Win11右下角時間怎么顯示星期幾?
- 2022-08-21 Python?Map函數(shù)保姆級使用教程_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支