自己写的一个根据结点名称查找CTreeCtrl树中对应结点的方法(用的是递归思想)

//hroot:待遍历树的根节点,strname:待查找节点名称
HTREEITEM finditem(HTREEITEM hroot, CString strname 

  
     HTREEITEM hfind;   

//表明此树是空树,直接返回NULL
     if(hroot== NULL)   
          return NULL;   
//否则遍历查找
    while(hroot!=NULL)   
    {   
 //当前节点即所需查找节点
         if(GetItemText(hroot) ==strname  
            return hroot  
//查找当前节点的子节点
         if(ItemHasChildren(hroot))   
          
             hroot= GetChildItem(hroot);  
             //递归调用查找子节点下节点
             hfind = finditem(hroot,strname);   
             if(hfind)   
            {   
                  return hfind;   
            }else 

//子节点中未发现所需节点,继续查找兄弟节点
             hroot= GetNextSiblingItem(GetParentItem(hroot));   
       }   
       else{ 

//若无子节点,继续查找兄弟节点
            hroot= GetNextSiblingItem(hroot);   
      }   
  }   
  return hroot 
}


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值