내 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"보다 더 좋은 이름을 준 때문에?. 죄송합니다. 저항 할 수 없습니다. –
PF로 printf를 알리면 나를 조금만 더 죽게됩니다. – Corbin
단순한'return * ip1 - * ip2'는'intcmp'의 전신으로 충분하지 않습니까? 왜 그는 두 개의 포인터가 더 필요했을까요? o__O –