📄 lsearch.c
字号:
#if !defined(lint) && defined(SCCSIDS)static char sccsid[] = "@(#)lsearch.c 1.1 92/07/30 SMI"; /* from S5R2 1.8 */#endif/*LINTLIBRARY*//* * Linear search algorithm, generalized from Knuth (6.1) Algorithm Q. * * This version no longer has anything to do with Knuth's Algorithm Q, * which first copies the new element into the table, then looks for it. * The assumption there was that the cost of checking for the end of the * table before each comparison outweighed the cost of the comparison, which * isn't true when an arbitrary comparison function must be called and when the * copy itself takes a significant number of cycles. * Actually, it has now reverted to Algorithm S, which is "simpler." */typedef char *POINTER;extern POINTER memcpy();POINTERlsearch(key, base, nelp, width, compar)register POINTER key; /* Key to be located */register POINTER base; /* Beginning of table */unsigned *nelp; /* Pointer to current table size */register unsigned width; /* Width of an element (bytes) */int (*compar)(); /* Comparison function */{ register POINTER next = base + *nelp * width; /* End of table */ for ( ; base < next; base += width) if ((*compar)(key, base) == 0) return (base); /* Key found */ ++*nelp; /* Not found, add to table */ return (memcpy(base, key, (int)width)); /* base now == next */}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -