Або поєднання двох підходів:
_Bool starts_with(const char *restrict string, const char *restrict prefix)
{
char * const restrict prefix_end = prefix + 13;
while (1)
{
if ( 0 == *prefix )
return 1;
if ( *prefix++ != *string++)
return 0;
if ( prefix_end <= prefix )
return 0 == strncmp(prefix, string, strlen(prefix));
}
}
EDIT: Наведений нижче код НЕ працює, оскільки якщо strncmp повертає 0, невідомо, чи було досягнуто кінцеве значення 0 або довжина (block_size).
Додатковою ідеєю є порівняння за блоками. Якщо блок не рівний, порівняйте цей блок із вихідною функцією:
_Bool starts_with_big(const char *restrict string, const char *restrict prefix)
{
size_t block_size = 64;
while (1)
{
if ( 0 != strncmp( string, prefix, block_size ) )
return starts_with( string, prefix);
string += block_size;
prefix += block_size;
if ( block_size < 4096 )
block_size *= 2;
}
}
Константи 13
, 64
, 4096
, а також експоненціація block_size
лише здогадки. Його потрібно було б вибрати для використовуваних вхідних даних та обладнання.