⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lsearch.c

📁 <B>Digital的Unix操作系统VAX 4.2源码</B>
💻 C
字号:
/*	@(#)lsearch.c	1.8	*//*	3.0 SID #	1.2	*//*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 + -