bsearch.c

来自「操作系统源代码」· C语言 代码 · 共 29 行

C
29
字号
/* * (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands. * See the copyright notice in the ACK home directory, in the file "Copyright". *//* $Header: bsearch.c,v 1.2 89/12/18 15:12:21 eck Exp $ */#include	<stdlib.h>void *bsearch(register const void *key, register const void *base,	register size_t nmemb, register size_t size,	int (*compar)(const void *, const void *)){	register const void *mid_point;	register int  cmp;	while (nmemb > 0) {		mid_point = (char *)base + size * (nmemb >> 1);		if ((cmp = (*compar)(key, mid_point)) == 0)			return (void *)mid_point;		if (cmp >= 0) {			base  = (char *)mid_point + size;			nmemb = (nmemb - 1) >> 1;		} else			nmemb >>= 1;	}	return (void *)NULL;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?