查找算法--二分法

二分查找算法的基本思想:

一.首先确定该区间的中间元素位置:mid = (low + high)/2;

   mid代表区间内中间元素的位置

   low代表区间内最左边元素的位置

   high代表区间内最右边元素的位置

二.将待查key元素值与中间元素mid的值(array[mid])比较,如果相等,则查找成功,否则确定新的查找区间。

  如果array[mid]>key,则由表的有序性可知,array[mid]右侧的值都大于key,所以等于key的元素如果存在,必然在array[mid]左边的区间中,这时候high = mid- 1;

  如果array[mid]<key,则等于key的元素如果存在,必然在array[mid]右边的区间中,这时候low = mid+1;

  如果array[mid]=key,则查找成功。

三.如果当前区间查找不存在,则继续重复第一二步骤。

四.在查找过程中,low逐步增加,high逐步减少,如果high<low,则查找失败。


二分法时间复杂度

如果是无序的一组数据,只能用顺序查找时间复杂度O(n),当然我们也可以 先用排序算法让无序变为有序,不过排序的过程也是一个损耗。

如果是有序的一组数据,我们可以直接使用二分查找(也称折半查找),有序也是二分查找的一个基本前提。使用二分的话,假设有1000个数,最坏的情况是要查找(log1000)/(log2)这么多次,所以时间复杂度为O(logn)。

实现代码:

void Binary(int *array,int length,int key){
    int low = 0;
    int high = length - 1;
    int mid = (low + high)/2;
    while (low <= high && array[mid] != key) {
        if (key > array[mid]) {
            low = mid + 1;
        } else {
            high = mid - 1;
        }
        mid = (low + high)/2;
    }
    if (array[mid] == key) {
        printf("找到啦!\n");
        return;
    }
    printf("没找到!\n");
    return;
}

int main(int argc, const char * argv[]) {
    // insert code here...
    int a[10] = {1,2,3,4,5,6,7,8,9,10};
    Binary(a,10,8);
    printf("Hello, World!\n");
    return 0;
}



以下是Dev-C++实现顺序查找算法二分法查找算法的示例代码: ```c++ #include <iostream> #include <vector> #include <algorithm> using namespace std; // 顺序查找算法 int seqSearch(vector<int>& nums, int target) { for (int i = 0; i < nums.size(); i++) { if (nums[i] == target) { return i; } } return -1; // 查找失败 } // 二分法查找算法 int binarySearch(vector<int>& nums, int target) { int left = 0, right = nums.size() - 1; while (left <= right) { int mid = (left + right) / 2; if (nums[mid] == target) { return mid; } else if (nums[mid] < target) { left = mid + 1; } else { right = mid - 1; } } return -1; // 查找失败 } int main() { vector<int> nums = {3, 5, 2, 8, 4, 7, 1, 6}; sort(nums.begin(), nums.end()); // 二分法查找算法需要有序表 int target = 4; int index1 = seqSearch(nums, target); // 调用顺序查找算法 int index2 = binarySearch(nums, target); // 调用二分法查找算法 if (index1 != -1) { cout << "顺序查找成功,目标元素下标为:" << index1 << endl; } else { cout << "顺序查找失败,未找到目标元素" << endl; } if (index2 != -1) { cout << "二分法查找成功,目标元素下标为:" << index2 << endl; } else { cout << "二分法查找失败,未找到目标元素" << endl; } return 0; } ``` 以上代码中,我们使用了STL中的vector容器来存储顺序表元素,并使用sort函数对其进行排序,以便二分法查找算法能够正确执行。在main函数中,我们分别调用了顺序查找算法二分法查找算法查找目标元素的值为4。最后,根据返回的下标值,输出查找结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值