完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1 泛型函数bsearch()的编写过程
1.1 先实现对整型数组的查找 int8_t BinarySearch(int key, int *arr, uint8_t arrLen) { uint8_t low = 0; uint8_t high = arrLen-1; uint8_t middle; // In ascending order while(low <= high) { middle = (low + high)>>1; if(arr[middle] == key) { return middle; } else if (arr[middle] > key) { high = middle - 1; } else { low = middle + 1; } } return -1; } 1.2 尝试使用泛型 /** * 问题1:遇到负数使用 memcmp 就完蛋了!!! * 问题2:无法支持指针数组 **/ void *bsearch(void *key, void *arr, uint8_t arrLen, uint8_t elemSize) { uint8_t low = 0; uint8_t high = arrLen - 1; uint8_t middle; void *elemAddr; // In ascending order while(low <= high) { middle = (low + high) >> 1; elemAddr = (char *)arr + middle * elemSize; if(0 == memcmp(key, elemAddr, elemSize)) { return elemAddr; } else if(memcmp(key, elemAddr, elemSize) > 0 ) { low = middle + 1; } else { high = middle - 1; } } return NULL; } 1.3 增加对负数和指针数组的支持 void *bsearch(void *key, void *arr, uint8_t arrLen, uint8_t elemSize, int cmpFn(void*, void*)) { uint8_t low = 0; uint8_t high = arrLen - 1; uint8_t middle; void *elemAddr; int result; // In ascending order while(low <= high) { middle = (low + high) >> 1; elemAddr = (char *)arr + middle * elemSize; result = cmpFn(key, elemAddr); if(0 == result) { return elemAddr; } else if(result > 0 ) { low = middle + 1; } else { high = middle - 1; } } return NULL; } int bIntCmp(void *elem1, void *elem2) { int *ip1 = (int *)elem1; int *ip2 = (int *)elem2; return *ip1 - *ip2; } int bStrCmp(void *elem1, void *elem2) { char *cp1 = *(char **)elem1; char *cp2 = *(char **)elem2; return strcmp(cp1, cp2); } 2 测试 2.1 对指针数组的二分查找 int arr[] = {-100, -25, -1, 0, 1, 5, 6, 10, 11, 12, 15}; char *str[] = { // ordered list, ascending order "ab", "abc", "abcd", "abcde" }; int main (int argc, char *argv[]) { char *strKey = "abc"; void *get; printf("there are %d elems in arrayrn", sizeof(str)/sizeof(char *)); get = bsearch( &strKey, &str, sizeof(str)/sizeof(char *), sizeof(char *), bStrCmp); if(NULL != get) { printf( "taget %s was founded in position %drn", strKey, (char **)get - str); } else { printf("Not foundedrn"); } return 0; } |
|
|
|
只有小组成员才能发言,加入小组>>
imx6ull 和 lan8742 工作起来不正常, ping 老是丢包
3406 浏览 0 评论
3381 浏览 9 评论
3067 浏览 16 评论
3556 浏览 1 评论
9198 浏览 16 评论
1317浏览 3评论
678浏览 2评论
const uint16_t Tab[10]={0}; const uint16_t *p; p = Tab;//报错是怎么回事?
671浏览 2评论
用NUC131单片机UART3作为打印口,但printf没有输出东西是什么原因?
2422浏览 2评论
NUC980DK61YC启动随机性出现Err-DDR是为什么?
1984浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-3-5 12:22 , Processed in 1.112958 second(s), Total 49, Slave 40 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191