二分查找 - Go语言 -- 十安辰

本文深入讲解了二分查找算法的基本思想、适用条件及代码实现,包括迭代和递归两种方式,对比了它们的优缺点,适合对算法感兴趣的读者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、顺序查找

思想:遍历数组,判断每一个元素是否与要查找元素匹配,简单,略


二、二分查找

1、思想

首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

2、算法要求

  1. 必须采用顺序存储结构
  2. 必须按关键字大小有序排列。

三、代码实现

func BinarySearch(n []int, target int) int {
   length := len(n)   
   low := 0   
   high := length - 1
   for low <= high {
         mid := (low + high) / 2      
         if n[mid] > target {		//比较,中间元素大于查找目标,则查找目标在前半段
             high = mid - 1
         } else if n[mid] < target {	//比较,中间元素小于查找目标,则查找目标在后半段
             low = mid + 1      
         } else {         			//目标就是中间元素。直接返回
             return mid      
         }   
    }
    return -1 //查找失败,返回-1
}

四、验证

这里用另一种方法,递归,这种方法需要注意递归截止条件,内存开销也比上述函数大

package main

import (
	"fmt"
)

//二分查找的函数
/*
二分查找的思路: 比如我们要查找的数是 findVal
1.arr 是一个有序数组,并且是从小到大排序
2.先找到 中间的下标 middle = (leftIndex + rightIndex) / 2, 然后让 中间下标的值和 findVal 进行比较
2.1如果 arr[middle] > findVal ,	就应该向	leftIndex	(middle - 1)
2.2如果 arr[middle] < findVal ,	就应该向	middel+1	rightIndex
2.3如果 arr[middle] == findVal , 就找到
2.4上面的 2.1 2.2 2.3 的逻辑会递归执行
3.想一下,怎么样的情况下,就说明找不到[分析出退出递归的条件!!] if	leftIndex > rightIndex {
// 找不到.. return ..
}
*/
func BinaryFind(arr *[6]int, leftIndex int, rightIndex int, findVal int) {

	//判断 leftIndex 是否大于 rightIndex if leftIndex > rightIndex {
	if leftIndex > rightIndex {
		fmt.Println("找不到")
		return
	}
	//先找到 中间的下标
	middle := (leftIndex + rightIndex) / 2
	if (*arr)[middle] > findVal {
		//说明我们要查找的数,应该在	leftIndex --- middel-1
		BinaryFind(arr, leftIndex, middle - 1, findVal)
	} else if (*arr)[middle] < findVal {
		//说明我们要查找的数,应该在	middel+1 --- rightIndex
		BinaryFind(arr, middle + 1, rightIndex, findVal)
	} else {
		//找到了
		fmt.Printf("找到了,下标为%v \n", middle)
	}
}

func main() {
	arr := [6]int{1, 8, 10, 89, 1000, 1234}
	//测试一把
	BinaryFind(&arr, 0, len(arr)-1, -6)
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值