BUPT-homework/semester3/pset4/7-3-航空公司VIP客户查询.c

95 lines
1.7 KiB
C
Raw Permalink Normal View History

2022-11-02 10:28:10 +08:00
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
2022-11-02 10:33:47 +08:00
// when size is too small, the table will overflow.
2022-11-02 10:28:10 +08:00
#define SIZE 100023
#define IDLEN 19
#define P 13
2022-11-13 21:16:43 +08:00
typedef struct {
2022-11-02 10:28:10 +08:00
int m;
int p;
char **key;
int *answer;
} hashTable;
hashTable *newHash() {
hashTable *h = malloc(sizeof(hashTable));
h->m = SIZE;
h->p = P;
h->key = malloc(sizeof(char *) * SIZE);
for (int i = 0; i < SIZE; i++) {
h->key[i] = malloc(sizeof(char) * IDLEN);
h->key[i][0] = '#';
h->key[i][1] = '\0';
}
h->answer = malloc(sizeof(int) * SIZE);
for (int i = 0; i < SIZE; i++) {
h->answer[i] = 0;
}
return h;
}
int hash(hashTable *h, char *str) {
int m = h->m;
int p = h->p;
int ans = 0;
int p_pow = 1;
for (int i = 0; i < IDLEN - 1; i++) {
if (str[i] == 'x') {
ans = (ans + 11 * p_pow) % m;
} else {
ans = (ans + (str[i] - '0' + 1) * p_pow) % m;
}
p_pow = (p_pow * p) % m;
}
int quad = 1;
while (h->key[ans][0] != '#' && strcmp(h->key[ans], str) != 0) {
// collision
ans = (ans + quad * quad) % m;
quad++;
}
return ans;
}
int max(int l, int r) { return (l > r) ? l : r; }
int main(void) {
int n, k;
scanf("%d%d", &n, &k);
char buf[IDLEN];
int tmp;
hashTable *h = newHash();
int strHash;
for (int i = 0; i < n; i++) {
scanf("%s%d", buf, &tmp);
strHash = hash(h, buf);
strcpy(h->key[strHash], buf);
h->answer[strHash] += max(k, tmp);
}
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%s", buf);
strHash = hash(h, buf);
if (h->key[strHash][0] == '#') {
printf("No Info\n");
} else {
printf("%d\n", h->answer[strHash]);
}
}
return 0;
}