template <typename HashedObj>
class HashTable{
public:
explicit HashTable(int size=101);
bool remove(const HashedObj& x);
private:
vector<list<HashedObj> >theLists;
int currentSize;
typedef list<HashedObj>::iterator Litr;
Litr& find(const Litr& start,const Litr& end,const HashedObj& x) const{
for(Litr itr=start;itr!=end;itr++)
if(x==*itr)
return itr;
return end;
}
};
上面代码没给完整,只给了出问题的部分大概意思就是一个分离链接法的散列表实现,然后remove函数里想用一个list<HashedObj>类型的迭代器来完成查询和删除工作,然后编译提示如下:need 'typename' before 'std::list<HashedObj>::iterator' because 'std::list<HashedObj>' is a dependent scope
需要显式的对这个iterator进行声明这是