main.c 731 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #include <assert.h>
  2. #include <stdbool.h>
  3. #include <stdio.h>
  4. #include <string.h>
  5. #include "keys.code.h"
  6. int hash_g (char *s, int *T)
  7. {
  8. int i, f = 0;
  9. for (i = 0; s[i] != '\0'; i++) {
  10. f += T[i] * s[i];
  11. f %= NG;
  12. }
  13. return G[f];
  14. }
  15. int hash (char *k)
  16. {
  17. if (strlen (k) > NS)
  18. return 0;
  19. return (hash_g (k, T1) + hash_g (k, T2)) % NG;
  20. }
  21. bool has_key (char *k)
  22. {
  23. int h = hash (k);
  24. return h < NK && strcmp(k, K[h]) == 0;
  25. }
  26. int main ()
  27. {
  28. int i;
  29. char *junk = "acnhuvn5yushvghnw7og5siuhgsiuhnglsh45vgghwn";
  30. assert (has_key(junk) == 0);
  31. assert (hash(junk) == 0);
  32. for (i = 0; i < NK; i++) {
  33. assert (has_key(K[i]) == true);
  34. assert (hash(K[i]) == i);
  35. }
  36. puts ("OK");
  37. return 0;
  38. }