Chinaunix首页 | 论坛 | 博客
  • 博客访问: 237100
  • 博文数量: 108
  • 博客积分: 3092
  • 博客等级: 中校
  • 技术积分: 1172
  • 用 户 组: 普通用户
  • 注册时间: 2008-07-25 16:35
文章分类

全部博文(108)

文章存档

2011年(3)

2010年(43)

2009年(19)

2008年(43)

我的朋友

分类: C/C++

2009-02-25 21:53:19

1.相对链表的O(N)的平均访问时间,树的为O(lgN)
2.一棵树是N个节点和N-1条变的集合
3.一般树的实现
  struct treenode
  {
     elementtype element;
     ptrtonode firstchild;//纵向链表,指向该节点的第一个儿子
     ptrtonode nextsibling;//横向链表,指向儿子链表的下一个元素(下一兄弟)
  }
 
4.二叉树
二叉树是一棵树,每个节点有不多于两个的儿子。平均深度为O(sqrt(N))
实现:
  struct treenode
  {
     elementtype element;
     tree left;
     tree right;
  }
 
5.二叉查找树
对于二叉查找树中的每一个节点X,其左子树中所有关键字的值都小于X,右子树则大于X。二叉查找树的平均深度为O(lgN)。
1)清空
makeempty(searchtree T)
{
    if(T!=null)
    {
       makeempty(T->left);
       makeempty(T->right);
       free(T);
    }
    return null;
}
 
2)查找
find(elementtype X,tree T)
{
    if(T==NULL)
      return null;
    if(Xelement)
      find(X,T->left);
    else if(X>T->element)
      find(X,T->left);
    else
      return T;
}
 
在所有的实现中都要注意“边界情况”的处理,如对空树的判断和处理。
insert(elementtype X,tree T)
{
    if(T==NULL)
    {
       T=maloc(sizeof(treenode));
       if(T==NULL)
          FATALERROR("out of space");
       else
       {
          T->element=X;
          T->left=T->right=null;
       }
    }
    else
    if(Xleft)
       T->left=insert(X,T->left);
    else
    if(X>T->right)
       T->right=insert(X,T->right);
    return T;
}
 
3)删除
delete(elementtype X,T)
{
   if(T==NULL)
     ERROR("EMPTY TREE");
   else
   if(Xelement)
     delete(X,T->left);
   else
   if(X>T->element)
     delete(X,T->right);
   else
   if(T->right&&T->left)
   {
     tmpnode=findsmall(T->right);
     T->element=tmpnode->element;
     T->right=delete(tmpnode->element,T->right);
   }
   else
   {
     tmpt=T;
     if(T->left==NULL)
        T=T->right;
     else
     if(T->right==NULL)
        T=T->left;
     free(tmpt);
    }
   
   }
       
  return T;
}
 
如果删除的次数不多,通常会采用的策略是懒惰删除,当一个元素要被删除时,它仍然留在树中,只是被标记为无效。 
阅读(613) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~