不少航空公司都會提供優惠的會員服務,當某顧客飛行里程累積達到一定數量后,可以使用里程積分直接兌換獎勵機票或獎勵升艙等服務。現給定某航空公司全體會員的飛行記錄,要求實現根據身份證號碼快速查詢會員里程積分的功能。
輸入格式:
輸入首先給出兩個正整數NN(\le 10^5≤105)和KK(\le 500≤500)。其中KK是最低里程,即為照顧乘坐短程航班的會員,航空公司還會將航程低於KK公里的航班也按KK公里累積。隨后NN行,每行給出一條飛行記錄。飛行記錄的輸入格式為:18位身份證號碼(空格)飛行里程
。其中身份證號碼由17位數字加最后一位校驗碼組成,校驗碼的取值范圍為0~9和x共11個符號;飛行里程單位為公里,是(0, 15 000]區間內的整數。然后給出一個正整數MM(\le 10^5≤105),隨后給出MM行查詢人的身份證號碼。
輸出格式:
對每個查詢人,給出其當前的里程累積值。如果該人不是會員,則輸出No Info
。每個查詢結果占一行。
輸入樣例:
4 500
330106199010080419 499
110108198403100012 15000
120104195510156021 800
330106199010080419 1
4
120104195510156021
110108198403100012
330106199010080419
33010619901008041x
輸出樣例:
800 15000 1000 No Info
注意hash函數的選取,一開始我選取了后四位果斷超時,選取了后五位即可AC,盡量讓Hash函數取值接近數據最大值,這樣能減少很多沖突。
#include<cstdio> #include<cstdlib> #include<cstring> #include<iostream> using namespace std; #define MAXN 10005 typedef long long LL; /* hash表 */ typedef struct node { char id[20]; LL miles; struct node* next; }*List; typedef struct tb { LL Tablesize; List *list; }*Hashlist; LL Hash(char key[],LL size) { LL tmp = 0; for(LL i=13;i<18;i++) { if(key[i]=='x') tmp = (tmp*10+10)%size; else tmp = (tmp*10 + key[i]-'0')%size; } return tmp; } LL NextPrim(LL x) { LL j; for(LL i=x;;i++) { for(j=2;j*j<=i;j++) if(i%j==0) break; if(j*j>i) return i; } } Hashlist Init(LL size) { Hashlist H = (Hashlist)malloc(sizeof(tb)); H->Tablesize = NextPrim(size); H->list = (List*)malloc(sizeof(List)*H->Tablesize); for(LL i=0;i<H->Tablesize;i++) { H->list[i] = (List)malloc(sizeof(node)); H->list[i]->next = NULL; } return H; } List Find(char key[],Hashlist H) { List t = H->list[Hash(key,H->Tablesize)]; List p = t->next; while(p!=NULL && strcmp(key,p->id)) p = p->next; return p; } void Insert(char key[],LL miles,Hashlist H) { List t = H->list[Hash(key,H->Tablesize)]; List f = Find(key,H); if(f==NULL) { List tmp = (List)malloc(sizeof(node)); tmp->miles = miles; strcpy(tmp->id,key); tmp->next = t->next; t->next = tmp; } else { (f->miles) += miles; } } int main() { char id[20]; LL tmp,n,m,k; scanf("%lld%lld",&n,&k); Hashlist H = Init(n); for(LL i=0;i<n;i++) { scanf("%s%lld",id,&tmp); if(tmp<k) tmp = k; Insert(id,tmp,H); } scanf("%lld",&m); for(LL j=0;j<m;j++) { scanf("%s",id); List f = Find(id,H); if(f==NULL) printf("No Info\n"); else printf("%lld\n",f->miles); } }