设为首页  
联系我们  
加入收藏  
网页制作 冲浪宝典 图形图像 操作系统 软件教学 编程开发 认证考试 安全技术 站长专区 文学驿站 娱乐天地 游戏天地 办公软件
文章搜索
您的位置: 首页 >> 文章首页 >> 编程开发 >> 其他开发语言 >> 今天学数据结构, 写了HASH, 学习中, 坚持;
精品推荐
其他开发语言点击TOP10
·数字小键盘指法练习
·用C语言编通讯录程序(初学者级别的)
·Modem 常用AT指令集
·单片机模拟I2C总线及24C02(I2C EEPROM)读写实例(源代码)
·C++经典电子书下载
·Thinking in C++ 简体中文第二版
·debug和release的区别
·error LNK2001: unresolved external symbol __ftol2 错误解决
·C库函数手册
·一个简单的C语言编译器
编程开发点击TOP10
·数字小键盘指法练习
·ASP.NET 程序中常用的三十三种代码
·用C语言编通讯录程序(初学者级别的)
·我写的Java学生成绩管理系统源代码
·CHK文件恢复工具
·Modem 常用AT指令集
·java笔试题
·异常java.sql.SQLException: Io exception:The Network Adapter could not establish connection
·单片机模拟I2C总线及24C02(I2C EEPROM)读写实例(源代码)
·C++经典电子书下载
精选专题

今天学数据结构, 写了HASH, 学习中, 坚持;

作者: 来源:网络文章 时间:2005-12-17 18:48:22

今天学数据结构, 写了HASH, 学习中, 坚持;(1)

template<typename T, typename Key = unsigned int>
class hash
{
 strUCt node
 {
  Key _key;
  T _data;
  node *_next;
  node(const Key &key, const T &x) : _key(key), _data(x), _next(NULL)  {  }
 };

 node **_head;
 unsigned int _mod;

public:

 hash(unsigned int mod = 13) : _mod(mod)
 {
  assert(mod);
  _head = new node*[_mod];
  memset(_head, 0, sizeof(node *) * _mod);
 }

 ~hash()
 {
  clear();
  delete[] _head;
 }

 void clear()
 {
  for(int i = 0; i < _mod; i++)
  {
   for(node *p; _head[i]; )
   {
    p = _head[i], _head[i] = _head[i]->_next;
    delete p;
   }
   _head[i] = NULL;
  }
 }

 void visit(void func(unsigned int, const Key &, const T &))
 {
  for(int i = 0; i < _mod; i++)
   for(node *p = _head[i]; p; p = p->_next)
    func(i + 1, p->_key, p->_data);
 }

 void push(const Key &key, const T &x)
 {
  unsigned int i = (unsigned int)key % _mod;

  if(_head[i])
  {
   for(node *p = _head[i]; p && p->_key != key; p = p->_next)
   {
    if(!p->_next)
    {
     p->_next = new node(key, x);
     break;
    }
   }
  }
  else
   _head[i] = new node(key, x);

共3页 9 7 [1] [2] [38 :>

今天学数据结构, 写了HASH, 学习中, 坚持; 相关文章:
今天学数据结构, 写了HASH, 学习中, 坚持; 相关软件:
特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
转载请注明来源:http://www.xgdown.com