结构体递归查找

261 篇文章 10 订阅
该代码段展示了如何使用C++遍历并查找一个包含子项的集合。函数`boolIsFind`通过迭代`vecInfo`向量,对比`strParent`与每个元素的`strID`,当找到匹配项时返回`true`。同时,函数还递归地检查每个元素的子向量`subvecItems`以查找匹配项。如果在子向量中找到匹配项,也会立即返回`true`。
摘要由CSDN通过智能技术生成

bool IsFind(CString& strParent,vector<DETAIL_INFO> &vecInfo)
{
    bool bFind = false;
    for (vector<DETAIL_INFO>::iterator itr = vecInfo.begin(); itr != vecInfo.end(); ++itr)
    {
        if (itr->strID == strParent)
        {
            m_pInfo = &*itr;
            return true;
        }
        if (!itr->subvecItems.empty()) 
            bFind = IsFind(strParent, itr->subvecItems);
        if (bFind) return true;
        
    }
    return false;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值