循环和递归

wojiushiwangxiong 2014-12-17 08:02:12
比如有这样的一张表,表的结构为ID和父ID
如下:
(2,1)
(3,1)
(4,1)
(5,2)
(6,3)
(7,4)
(8,4),这样如果我想查询根节点为1这个父ID下的所有记录
那么我的循环语句怎么写,递归怎么写呢?
结果是2,3,4,5,6,7,8
谢谢了。
...全文
102 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2014-12-18
  • 打赏
  • 举报
回复
不超过一万条用循环
l4kangaxx 2014-12-18
  • 打赏
  • 举报
回复

//递归
struct Record
{
    int Id;
    int ParentId;
}
void FindIdRescure(vector<int> &out,vector<Record> in, int ParentId)  //此算法内存方面的细节可以优化,lz你忽视好了。
{
    for(int i = 0;i<in.size();i++){
         if(in[i].ParentId == ParentId)
         {
             out.push_back(in[i].Id);
             FindIdRescure(out,in,in[i].Id);
         }
}

int main()
{
    vector<Record> list;
    Record r21; r21.Id = 2 ; r21.ParentId = 1;
    list.push_back(r21);
    Record r31; r31.Id = 3; r31.ParentId = 1;
    list.push_back(r31);
    // ... 略;
    vector<int> out;
    FindIdRescure(out,list,1);
}  
iyomumx 2014-12-18
  • 打赏
  • 举报
回复
参考,循环直接写在main里了:
#include <iostream>
#include <vector>
#include <deque>
#include <future>

using namespace std;

vector<int> FindChildren(const vector<pair<int, int>> data, const int id)
{
    vector<int> result;
    vector<future<vector<int>>> futures;
    for (auto& p : data)
    {
        //找到符合的数据,将其ID加入结果列表
        if (p.second == id)
        {
            result.push_back(p.first);
            //递归查找该ID的子ID,将递归结果缓存
            futures.push_back(async(FindChildren, data, p.first));
        }
    }
    //将递归结果加入结果列表
    for (auto& f : futures)
    {
        for (auto& c : f.get())
        {
            result.push_back(c);
        }
    }
    return result;
}

int main()
{
    //数据
    vector<pair<int, int>> data = { { 2, 1 }, { 3, 1 }, { 4, 1 }, { 5, 2 }, { 6, 3 }, { 7, 4 }, { 8, 4 } };
    //待查ID队列
    deque<int> ids = { 1 };
    while (!ids.empty())
    {
        //取出队列尾部ID进行下一轮查找
        const int id = ids.back();
        ids.pop_back();
        for (auto& p : data)
        {
            if (p.second == id)
            {
                //找到符合的数据,将其ID加入查找队列
                ids.push_front(p.first);
                cout << p.first << " ";
            }
        }
    }
    cout << endl;
    //输出递归结果
    for (auto& c : FindChildren(data, 1))
    {
        cout << c << " ";
    }
    cout << endl;
    return 0;
}
fly_dragon_fly 2014-12-17
  • 打赏
  • 举报
回复
循环用队列就可以了,

64,682

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧