简单二分查找-golang

15 篇文章 0 订阅
8 篇文章 0 订阅

又是程序员小灰的漫画,关于二分查找的,我写了个简单的实现。

不过实际写代码的过程中并不一帆风顺,有些特殊情况还是没有考虑到。

下面是源码:

var (
	ErrNotFound = errors.New("not found target")
)
func BinarySearch(data []int, target int) (int,error) {
	dataAmount := len(data)
	if dataAmount == 0 {
		return 0, ErrNotFound
	}
	start := 0
	end := dataAmount-1
	testIndex := (start+end)/2
	for {
		if data[testIndex] > target {
			end = testIndex
			testIndex = (start+end)/2
		} else if data[testIndex] < target {
			start = testIndex
			testIndex = (start+end)/2
		} else {
			return testIndex,nil
		}

		if start == end {
			break
		}
		if end == start+1 {
			if target == data[end] {
				return end,nil
			}
			if target == data[start] {
				return start,nil
			}
			break
		}
	}
	return 0,ErrNotFound
}

下面是测试用例:

func TestBinarySearch(t *testing.T) {
	var testcases = []struct{
		data []int
		target int
		index int
		err error
	}{
		{[]int{1,2,3,4,5,6,7,8,9}, 1,0,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 2,1,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 3,2,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 4,3,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 5,4,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 6,5,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 7,6,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 8,7,nil},
		{[]int{1,2,3,4,5,6,7,8,9}, 9,8,nil},
		{[]int{1,2,3,4}, 1,0,nil},
		{[]int{1,2,3,4}, 2,1,nil},
		{[]int{1,2,3,4}, 3,2,nil},
		{[]int{1,2,3,4}, 4,3,nil},
		{[]int{}, 3, 0, ErrNotFound},
		{[]int{1}, 3, 0, ErrNotFound},
		{[]int{1}, 1, 0, nil},
	}

	for i, testcase := range testcases {
		retIndex, err := BinarySearch(testcase.data, testcase.target)
		if retIndex != testcase.index || err != testcase.err {
			t.Errorf("testcases[%d] binary search failed", i)
			t.Error("test datas:", testcase.data)
			t.Errorf("test target:%d, get index[%d],get error[%v], want index[%d],want error[%v]",
				testcase.target,retIndex, err, testcase.index, testcase.err)
			return
		}
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值