美文网首页
golang sort包

golang sort包

作者: p_gerer | 来源:发表于2020-11-25 01:42 被阅读0次

    1.sort.Search(n, func(k int) bool)

    描述:search使用二分法进行查找,Search()方法回使用“二分查找”算法来搜索某指定切片[0:n],并返回能够使f(i)=true的最小的i(0<=i<n)值,并且会假定,如果f(i)=true,则f(i+1)=true,即对于切片[0:n],i之前的切片元素会使f()函数返回false,i及i之后的元素会使f()函数返回true。但是,当在切片中无法找到时f(i)=true的i时(此时切片元素都不能使f()函数返回true),Search()方法会返回n(而不是返回-1)
    源码如下:

    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
    }
    

    相关文章

      网友评论

          本文标题:golang sort包

          本文链接:https://www.haomeiwen.com/subject/iyrgiktx.html