首页 > 后端开发 > Golang > 正文

Golang sort/search切片二分查找实践

P粉602998670
发布: 2025-09-22 18:38:01
原创
736人浏览过
在Go中对切片进行二分查找需确保数据有序,sort包提供sort.Search实现灵活查找,通过条件函数定位首个不小于目标的索引,结合预定义函数如sort.SearchInts、sort.SearchStrings可简化操作,还可利用插入点保持有序。

golang sort/search切片二分查找实践

在Go语言中,对切片进行二分查找时,必须保证数据已排序标准库

sort
登录后复制
提供了高效且类型安全的工具,能快速实现查找、插入等操作。以下是实际使用中的常见场景和方法。

使用 sort.Search 进行自定义二分查找

sort.Search
登录后复制
是最灵活的方式,适用于任意有序切片。它接受长度 n 和一个判断条件 f(i),返回满足 f(i) 为 true 的最小索引。

例如:在一个升序整数切片中查找目标值的位置:

func binarySearch(arr []int, target int) int {
    i := sort.Search(len(arr), func(i int) bool {
        return arr[i] >= target
    })
    if i < len(arr) && arr[i] == target {
        return i
    }
    return -1 // 未找到
}
登录后复制

这个写法的关键在于条件函数

arr[i] >= target
登录后复制
,它定位第一个不小于目标值的位置,再通过额外判断确认是否相等。

使用预定义函数简化查找

对于常见类型,

sort
登录后复制
包提供了专用函数,代码更简洁:

立即学习go语言免费学习笔记(深入)”;

宣小二
宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

宣小二 21
查看详情 宣小二
  • sort.Ints(arr)
    登录后复制
    —— 对整型切片排序
  • sort.Strings(arr)
    登录后复制
    —— 对字符串切片排序
  • sort.SearchInts(arr, x)
    登录后复制
    —— 在已排序整型切片中查找 x
  • sort.SearchStrings(arr, x)
    登录后复制
    —— 在已排序字符串切片中查找 x
示例:快速查找字符串是否存在

names := []string{"Alice", "Bob", "Charlie"}
sort.Strings(names)
index := sort.SearchStrings(names, "Bob")
if index != len(names) && names[index] == "Bob" {
    fmt.Println("Found at", index)
}
登录后复制

插入新元素并保持有序

利用

sort.Search
登录后复制
找到插入点,可将新元素放入正确位置而不破坏顺序。

比如向有序整数切片插入一个数:

func insertSorted(arr []int, x int) []int {
    i := sort.Search(len(arr), func(i int) bool { return arr[i] >= x })
    arr = append(arr, 0)
    copy(arr[i+1:], arr[i:])
    arr[i] = x
    return arr
}
登录后复制

这段代码先用

Search
登录后复制
定位插入索引,然后扩展切片并移动后续元素。

基本上就这些。只要数据有序,

sort.Search
登录后复制
和配套函数就能高效完成查找与维护。关键是理解条件函数的语义:找“第一个满足 >= 目标”的位置。掌握这一点,各种二分操作都容易推导。

以上就是Golang sort/search切片二分查找实践的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号