基于C语言实现的二分法

编程知识 行业动态 更新时间:2024-06-13 00:21:52

二分法 适用于一个已经排好序的,不管是升序还是降序的有序数组。二分查找法:给定一个目标数字,去到这个有序的数组,查找是否存在这个数,如果存在这个数就返回对应的数字下标,如果不存在就返回-1.
left=0;
right=length-1;

mid=(left+right)/2

left从左往右遍历,如果遍历得到的mid值还是小于给定目标对应的数字就+1,即继续往右遍历
right从右往左遍历,如果遍历得到的mid值还是大于给定目标对应的数字就-1,即继续往左遍历
如果mid对应的数字刚好等于给定的目标数字就返回mid

int search(int* nums, int numsSize, int target){
    int left = 0;
    int right = numsSize-1;
    int mid = 0;
    //若left小于等于right,说明区间中元素不为0
    while(left<=right) {
        //更新查找下标mid的值
        middle = (left+right)/2;
        //此时target可能会在[left,mid-1]区间中
        if(nums[mid] > target) {
            right = mid-1;
        } 
        //此时target可能会在[mid+1,right]区间中
        else if(nums[mid] < target) {
            left = mid+1;
        } 
        //当前下标元素等于target值时,返回mid
        else if(nums[middle] == target){
            return mid;
        }
    }
    //若未找到target元素,返回-1
    return -1;}

更多推荐

基于C语言实现的二分法

本文发布于:2023-04-01 07:28:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/cfaf63865fc5fb00e295a982c50aa3d2.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:语言

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!