複製鏈接
請複製以下鏈接發送給好友

bsearch

鎖定
函數名: bsearch
功 能: 二分法搜索
中文名
bsearch
功 能
二分法搜索
用 法
void *bsearch
類    型
函數名

目錄

bsearch簡介

用 法: void *bsearch(const void *key, const void *base, size_t nelem, size_t width, int(*fcmp)(const void *, const void *));
語法:
#include <stdlib.h> void *bsearch( const void *key, const void *buf, size_t num, size_t size, int (*compare)(const void *, const void *) );
參數:第一個:要查找的關鍵字的指針。第二個:要查找的數組。第三個:被查找數組中的元素數量。第四個:每個元素的長度(以字節為單位)。第五個:指向比較函數的指針
功能: 函數用折半查找法在從數組元素buf[0]到buf[num-1] 匹配參數key。如果函數compare 的第一個參數小於第二個參數,返回負值;如果等於返回零值;如果大於返回正值。數組buf 中的元素應以升序排列。函數bsearch()的返回值是指向匹配項,如果沒有發現匹配項,返回NULL

bsearch程序例

程序例:
#include<stdlib.h>
#include<stdio.h>
#define NELEMS(arr) (sizeof(arr) / sizeof(arr[0]))
int numarray[] = {123, 145, 512, 627, 800, 933};
int numeric (const int *p1, const int *p2){
return(*p1 - *p2);
}
int lookup(int key){
int *itemptr;
// The cast of (int(*)(const void *,const void*)) is needed to avoid a type mismatch error at compile time
itemptr = (int *)bsearch (&key, numarray, NELEMS(numarray),
sizeof(int), (int(*)(const void *,const void *))numeric);
return (itemptr != NULL);
}
int main(void){
if (lookup(512)){
printf("512 is in the table.\n");
}
else{
printf("512 isn't in the table.\n");
}
return 0;
}
例2:
對一個字符數組進行排序並查找指定字符串的例子:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#define LENGTH(x) sizeof(x)/sizeof(x[0])
/**輸出數組元素
*\param arr:指向數組的指針
*\param len:數組元素的個數
*/
void print(char (*arr)[10],int len)
{
int i;
for (i=0;i<len;i++)
{
printf("%s ",arr[i]);
}
printf("\n");
}
int main()
{
char arr[][10]={"bac","bca","abc","acb","cba","cab"}; /* 定義二維字符數組*/
char *key="bca";/* 要查找的字符串*/
char *ptr=NULL; /* 字符指針*/
// 輸出未排序時字符數組的內容
printf("before qsort :");
print(arr,LENGTH(arr));
/* 使用qsort對字符數組排序*/
qsort((void *)arr,LENGTH(arr),sizeof(arr[0]),(int (*)(const void *,const void *))strcmp);
/* 輸出排序後字符數組的內容*/
printf("after qsort :");
print(arr,LENGTH(arr));
/* 採用二分查找查找指定字符*/
ptr=(char *)bsearch(key,arr,LENGTH(arr),sizeof(arr[0]),(int (*)(const void *,const void *))strcmp);
if (ptr)
{ /* 找到*/
printf("%s is in the array\n",key);
}
else/* 沒找到*/
{
printf("%s isn't in the array\n",key);
}
return 0;
}