我的lsearch
函數應該在我的數組中找到值11。它沒有,我不知道錯誤在哪裏。爲什麼這個代碼沒有找到值11?C線性搜索錯誤
#include <stdio.h>
#include <string.h>
#define PF printf
int main() {
int intcmp(void *ip1, void * ip2);
void * lsearch(void *key, void *base, int n, int elemSize,
int(* cmpfun)(void *, void *));
int arr[] = {4, 6, 2, 3, 11, 22, 15};
int n = sizeof(arr)/sizeof(int);
int key = 11;
int *found = lsearch(&key, &arr, n, sizeof(int), intcmp);
PF("found=%p", found);
return 1;
}
int intcmp(void *ip1, void * ip2) {
int *p1 = ip1;
int *p2 = ip2;
return *p1 - *p2 == 0;
}
void * lsearch(void *key, void *base, int n, int elemSize,
int(* cmpfun)(void *, void *)) {
int i;
for(i = 0; i < n; i ++) {
void *elemArr = (char *)base + i * elemSize;
if(cmpfun(key, elemArr) == 0)
return elemArr;
}
return NULL;
}
*爲什麼不是我發現那位11 *因爲你的父母給你比「潤版液11」更好的名字?對不起,無法抗拒。 – 2012-07-14 05:56:49
將PF與別名混爲一談,讓我有點內心死亡。 – Corbin 2012-07-14 05:57:58
作爲'intcmp'的整個主體是不是一個簡單的'return * ip1 - * ip2'?爲什麼他需要兩個指針? o__O – 2012-07-14 07:46:30