⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bsearch.c

📁 一组基础的C库的实现
💻 C
字号:
/* $Id: bsearch.c 262 2006-11-16 07:34:57Z solar $ *//* Release $Name$ *//* bsearch( const void *, const void *, size_t, size_t, int(*)( const void *, const void * ) )   This file is part of the Public Domain C Library (PDCLib).   Permission is granted to use, modify, and / or redistribute at will.*/#include <stdlib.h>#ifndef REGTESTvoid * bsearch( const void * key, const void * base, size_t nmemb, size_t size, int (*compar)( const void *, const void * ) ){    const void * pivot;    int rc;    int corr;    while ( nmemb )    {        /* algorithm needs -1 correction if remaining elements are an even number. */        corr = ( nmemb % 2 ) - 1;        nmemb /= 2;        pivot = (const char *)base + (nmemb * size);        rc = compar( key, pivot );        if ( rc > 0 )        {            base = (const char *)pivot + size;            nmemb += corr;        }        else if ( rc == 0 )        {            return (void *)pivot;        }    }    return NULL;}#endif#ifdef TEST#include <_PDCLIB_test.h>int compare( const void * left, const void * right ){    return *( (unsigned char *)left ) - *( (unsigned char *)right );}int main(){    BEGIN_TESTS;    TESTCASE( bsearch( "e", abcde, 4, 1, compare ) == NULL );    TESTCASE( bsearch( "e", abcde, 5, 1, compare ) == &abcde[4] );    TESTCASE( bsearch( "a", abcde + 1, 4, 1, compare ) == NULL );    TESTCASE( bsearch( "0", abcde, 1, 1, compare ) == NULL );    TESTCASE( bsearch( "a", abcde, 1, 1, compare ) == &abcde[0] );    TESTCASE( bsearch( "a", abcde, 0, 1, compare ) == NULL );    TESTCASE( bsearch( "e", abcde, 3, 2, compare ) == &abcde[4] );    TESTCASE( bsearch( "b", abcde, 3, 2, compare ) == NULL );    return TEST_RESULTS;}#endif

⌨️ 快捷键说明

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