順序表的二分查找

二分查找適用于有序的順序表

#include "stdio.h"
#include "stdlib.h"

//順序表的二分查找

typedef int ElementType;
typedef struct
{

    int length;
    int capacity;
    ElementType *array;
} SeqList;

int binarySearch(SeqList list, ElementType k)
{

    int low = 0, mid, high = list.length - 1;

    while (low <= high)
    {
        mid = (low + high) / 2;

        if (k == list.array[mid])
        {
            return 1;
        }
        else if (k < list.array[mid])
        {
            high = mid - 1; //list.array前半?yún)^(qū)域
        }
        else
        {
            low = mid + 1; //list.array后半?yún)^(qū)域
        }
    }
    return 0;
}
int main()
{
    int aList[] = {3, 66, 78, 99, 102, 111};

    SeqList list;
    list.length = sizeof(aList) / sizeof(aList[0]);
    list.array = (int *)malloc(sizeof(int *) * list.length);
    int i = 0;
    for (; i < list.length; i++)
    {
        list.array[i] = aList[i];
    }
    int a = binarySearch(list, 66);
    if (a == 1)
    {
        printf("已查找到");
    }
    else
    {
        printf("未查找到");
    }

    return 0;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容