亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

sort.Search,尋找一個不在切片中的數字

sort.Search,尋找一個不在切片中的數字

Go
Helenr 2021-08-23 17:10:27
我目前在我的項目中遇到一個問題,我必須找到切片中不存在的數字。我在golang網站上找到了工作代碼,這很好用。在我的項目中,我創建了一個空塊,讓 else 語句完成所有工作。我試圖更改代碼以刪除空塊,但每次都出錯,我最終找到了一個重現問題的示例:package mainimport (    "fmt"    "sort")func main() {    data := []int{27, 15, 8, 9, 12, 4, 17, 19, 21, 23, 25}    nr := 9    sort.Ints(data)    index := sort.Search(len(data), func(index int) bool { return data[index] == nr })    if index == len(data) {        fmt.Print("It's not in : ")        fmt.Println(nr)    } else {        fmt.Print("It's in! Index is at : ")        fmt.Println(index)    }}golang操場上的工作代碼!
查看完整描述

2 回答

?
RISEBY

TA貢獻1856條經驗 獲得超5個贊

例如,


package main


import (

    "fmt"

    "sort"

)


func main() {

    data := []int{27, 15, 8, 9, 12, 4, 17, 19, 21, 23, 25}

    sort.Ints(data)

    fmt.Println(data)

    x := 9

    notpresent := false

    i := sort.Search(len(data), func(i int) bool { return data[i] >= x })

    if i >= len(data) || data[i] != x {

        // x is not present in data,

        // but i is the index where it would be inserted.

        notpresent = true

    }

    fmt.Println(x, notpresent)

}

輸出:


[4 8 9 12 15 17 19 21 23 25 27]

9 false


查看完整回答
反對 回復 2021-08-23
?
叮當貓咪

TA貢獻1776條經驗 獲得超12個贊

我也遇到同樣的問題,因為我誤解了godoc sort Search.

如果調用者要查找切片中是否有 23,則必須單獨測試 data[i] == 23。

我認為這也意味著“文檔說 == 是允許的”。實際上,在sort.Search中作為參數的函數中,只能使用>=or <=,不能使用==。這句話意味著在獲得 index 之后i,您必須對其進行測試data[i] == 23以確保 23 在切片中。


查看完整回答
反對 回復 2021-08-23
  • 2 回答
  • 0 關注
  • 216 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號