2011年软考程序员考试复习笔试知识点整理(21)

来源:软件水平考试    发布时间:2012-11-05    软件水平考试视频    评论

  //简单的Hash表实现

  #include

  template

  class HashTable

  {

  public:

  HashTable(int Length)

  {

  Element = new _Type[Length];

  for(int i=0;i

  Element[i] = -1;

  this->Length = Length;

  Count = 0;

  }

  ~HashTable()

  {

  delete[] Element;

  }

  // Hash函数

  virtual int Hash(_Type Data)

  {

  return Data % Length;

  }

  // 再散列法

  virtual int ReHash(int Index,int Count)

  {

  return (Index + Count) % Length;

  }

  // 查找某个元素是否在表中

  virtual bool SerachHash(_TypeData,int& Index)

  {

  Index = Hash(Data);

  int Count = 0;

  while(Element[Index] != -1 &&Element[Index] != Data)

  Index = ReHash(Index,++Count);

  return Data == Element[Index] ? true :false;

  }

  virtual int SerachHash(_Type Data)

  {

  int Index = 0;

  if(SerachHash(Data,Index)) returnIndex;

  else return -1;

  }

  // 插入元素

  bool InsertHash(_Type Data)

  {

  int Index = 0;

  if(Count < Length &&!SerachHash(Data,Index))

  {

  Element[Index] = Data;

  Count++;

  return true;

  }

  return false;

  }

  // 设置Hash表长度

  void SetLength(int Length)

  {

  delete[] Element;

  Element = new _Type[Length];

  for(int i=0;i

  Element[i] = -1;

  this->Length = Length;

  }

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答