Область интересов - соответствие строк. Предположим, у меня есть такая структура.
typedef struct
{
char *name,
int (*function)();
} StringArray
StringArray s[] =
{
{"George", func1},
{"Paul", func2},
{"Ringo", func3},
{"John", func4},
{"", NULL} /* End of list */
}
В массиве фиксированное количество строк. Они жестко закодированы, как в примере. Если таблица изменится, возникнет необходимость переоценить качество хеш-функции.
Я хочу применить хеш-функцию к строке, и если строка соответствует одному в массиве, затем вызовите функцию. Для этого нужна идеальная хеш-функция. Не допускается коллизий. Целью хэширования является получение производительности O (1) при поиске.
Какие у вас идеи по созданию функции для этого?