C++ 如果hash_map<vector<unsigned short>,int>的时候,怎么写hash函数呢?

如题!如果hash_map的键为vector<unsignedshort>,那么该如何写hash函数!#pragmawarning(disable:4786)#inclu... 如题!如果hash_map的键为vector<unsigned short>,那么该如何写hash函数!
#pragma warning (disable:4786)
#include <iostream>
#include <algorithm>
#include <vector>
#include <iterator>
#include <ext\hash_map>

using namespace std;
using namespace __gnu_cxx;

struct MyVectorComp
{
size_t operator()(const vector<int> &v1) const
{
size_t hashval=0;
for(size_t i=0;i<v1.size();i++)
hashval+=v1[i];
return hashval;
}
};
typedef hash_map<vector<int>,int,MyVectorComp> MyHashMap;
typedef pair<vector<int>,int> InsertPair;
typedef pair<MyHashMap::iterator,bool> ReturnPair;
typedef hash_map<vector<int>,int,MyVectorComp>::iterator MyHashMapIter;
vector<int> TempItem;

MyHashMap TempA;
ReturnPair p1;
MyHashMapIter MyHashMap_Iter;
int main()
{
TempItem.push_back(3);
TempItem.push_back(4);
p1=TempA.insert(InsertPair(TempItem,0));
for(MyHashMap_Iter=TempA.begin();MyHashMap_Iter!=TempA.end();MyHashMap_Iter++)
{
for(vector<int>::iterator iter=MyHashMap_Iter->first.begin();iter!=MyHashMap_Iter->first.end();iter++)
{
cout<<*iter;
}
cout<<MyHashMap_Iter->second;
}
getchar();
return 0;
}

这个程序最后想把hash_map内的情况输出屏幕,有错误!(我没有财富值了,谢谢)
展开
 我来答
百度网友3b61c12
2011-06-01
知道答主
回答量:15
采纳率:0%
帮助的人:0
展开全部
错误提示一起发上来啊

vector<int>::iterator iter 是vector容器的迭代起不能被MyHashMapIter 也就是hash_map类型迭代起赋值吧~
追问
那该怎么输出hash_map里的数据情况呢!!!还有,自定义Key的话,还用写比较函数吗?
百度网友63d8546
2011-05-31 · 超过12用户采纳过TA的回答
知道答主
回答量:117
采纳率:0%
帮助的人:56.2万
展开全部
我没有用过这个东西,但是我感觉这句有问题
p1=TempA.insert(InsertPair(TempItem,0));
追问
这地方好像没错 错在for(vector::iterator iter=MyHashMap_Iter->first.begin();iter!=MyHashMap_Iter->first.end();iter++)
这地方!!!说什么609 E:\Dev-Cpp\include\c++\3.4.5\bits\stl_iterator.h invalid conversion from `const int* const' to `int*'
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式