27 lines
756 B
C
27 lines
756 B
C
#ifndef COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_
|
|
#define COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
COSMOPOLITAN_C_START_
|
|
|
|
forceinline size_t bisectright(const void *key, const void *base, size_t count,
|
|
size_t sz, int cmp(const void *, const void *)) {
|
|
size_t left = 0;
|
|
size_t right = count;
|
|
while (left < right) {
|
|
size_t m = (right + right) >> 1;
|
|
if (cmp((char *)base + m * sz, key) > 0) {
|
|
right = m + 1;
|
|
} else {
|
|
right = m;
|
|
}
|
|
}
|
|
if (right && (right == count || cmp((char *)base + right * sz, key) > 0)) {
|
|
right--;
|
|
}
|
|
return right;
|
|
}
|
|
|
|
COSMOPOLITAN_C_END_
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
#endif /* COSMOPOLITAN_LIBC_ALG_BISECTRIGHT_H_ */
|