main.go 758 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. // 二分查找法
  2. package main
  3. import "fmt"
  4. func main() {
  5. fmt.Println("hello")
  6. nums := []int{-5, -4, -3, -2, -1, 0, 1, 2, 4, 5}
  7. fmt.Println(searchInsert(nums, 3))
  8. }
  9. func searchInsert(nums []int, target int) int {
  10. l := 0
  11. r := len(nums) - 1
  12. m := (l + r) / 2
  13. flag := true
  14. for flag {
  15. //这里顺序要考究下
  16. if nums[r] < target {
  17. return r + 1
  18. }
  19. if nums[r] == target {
  20. return r
  21. }
  22. if nums[l] >= target {
  23. return l
  24. }
  25. //以上先考虑边界情况
  26. if nums[m] < target && target < nums[m+1] {
  27. return m + 1
  28. }
  29. if nums[m] == target {
  30. return m
  31. }
  32. if nums[m] < target {
  33. l = m
  34. m = (l + r) / 2
  35. }
  36. if nums[m] > target {
  37. r = m
  38. m = (l + r) / 2
  39. }
  40. }
  41. return m
  42. }