用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - c代码库

二分法搜索

2012-11-05 作者: 程序猿style举报

[c]代码库

#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 = 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;
}


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...