1

我有一个类“类”,它有一个成员 std::list,我想在该列表/树中搜索一个项目,特别是一个具有特定名称的项目。我的班级的基本表示如下:

#include <list>
#include <string>
class Class {
    std::string _name;
    std::list<Class*> _members;
public:
    Class(const std::string& name) : _name(name) {}
    void addMember(Class* member) { _members.push_back(member); }
    const std::string& name() const { return _name; }
    const std::list members() const { return _members; }
    Class* findItem(const std::string& name) const { ... }
};

我可以在 Class::findItem 中做这样的事情:

Class* Class::findItem(const std::string& n) const {
    std::list<Class>::const_iteratior i;
    for(i=_members.begin(); i!=_members.end(); ++i)
        if((*i)->name() == n) return *i;
    for(i=_members.begin(); i!=_members.end(); ++i) {
      Class* cls = (*i)->findItem(n);
      if(cls) return cls;
    }
    return 0;
}

但是,我想要发生的是 findItem() 将“最接近”的项目返回到搜索的项目。例如,如果这是我的树,每个字母代表列表层次结构中的一个级别,每个数字代表项目“值”。我希望 findItem(3) 返回 B(3),而不是 C(3)。

                        一个(1)
                        |
        ----------------------------------
        乙(2)乙(3)
         | |
--------------------- -----
C(3) C(4) C(4)
                 | |
            ---------------- ----------
            D(5) D(6) D(7) D(5) D(6)
4

4 回答 4

4

使用广度优先搜索。当您访问一个不等于查询值的节点​​时,您将该节点推到队列的后面。首先处理队列前面的节点。您找到的第一个匹配项将是最接近根的匹配项。

Class* Class::findItem(const std::string& n) const {
    std::list<Class>::const_iteratior i;
    std::queue<Class*> q;
    q.push(this);
    while (!q.empty()) {
        Class *c = q.front(); q.pop();
        if (c->name() == n) return c;
        for(i=c->_members.begin(); i!=c->_members.end(); ++i)
            q.push(i);
    }
    return NULL;
}
于 2009-04-16T21:10:32.973 回答
2

如果您采用广度优先搜索方式,即首先查看所有 B,然后查看所有 C,等等,您的匹配节点将自动成为最近的。

于 2009-04-16T21:11:24.890 回答
1

听起来您要求进行广度优先搜索

我认为你的问题可能与家庭作业有关,所以我不会在这里透露更多细节。

于 2009-04-16T21:09:59.107 回答
1

似乎您对执行BFS(广度搜索优先)感兴趣。实现它的最简单方法不是通过递归,而是使用FIFO队列,您可以在其中将相邻元素添加到最后要测试的元素,然后从队列中提取第一个元素以执行下一次检查。

插入的顺序是 [ A(1), B(2), B(3), C(3), ... ],你会在测试 C(3) 之前找到 B(3)。

于 2009-04-16T21:14:28.190 回答