sicily 1194 message blood 之失败篇

这是在我决定当一个进击的程序员后刷的第一道题,虽然用哈希表一直没过,但是我觉得是有纪念意义的。

我要使用set容器来做这一题了!!!

#include
   
   
    
    
#include
    
    
     
     
#include
     
     
      
      
using namespace std;

int getkey(string name) {
	int a = 378551;
	int b = 63689;
	int len, _key = 0;
	len = name.length();
	for (int i = 0; i < len; i++) {
		_key = _key * a + name[i];
		a = a * b;
	}
	return _key % 40000;
}

string trans(string name) {
	int len = name.length();
	string result;
	for (int i = 0; i < len; i++) {
		result.push_back(tolower(name[i]));
	}
	return result;
}
int main() {
	int n, m;
	while (cin >> n) {
		if (n == 0) break; // The input is terminated by n=0.
		cin >> m;
		int count = 0; // count是发了信息的朋友数量
		string hash[40000];
		string name;
		int key, t;
		for (int i = 0; i < n; i++) {
			cin >> name;
			key = getkey(trans(name)) % 40000;  // 取得哈希值
			t = 1;
			while (true) {  // 建立哈希表
				if (hash[key] == "") {
					hash[key] = name;
					break;
				}
				else {
					key = (key + t * 378551) % 40000;
					t++;
				}
			} // end while
		} // end for

		for (int j = 0; j < m; j++) {
			string sender;
			cin >> sender;
			key = getkey(trans(name)) % n;
			t = 0;
			while (true) {
				if (hash[key] == sender) {
					count++;
					hash[key] = "";
					break;
				}
				else if (hash[key] == "") {
					break;
				}
				else{
					key = (key + t * 378551) % 40000;
					t++;
				}
			} // end while
		} // end for
		delete hash;
		cout << n - count << endl; // 输出剩余没发过信息的朋友数
	}
	return 0;
}

     
     
    
    
   
   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值