首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >排序实体依赖关系

排序实体依赖关系
EN

Stack Overflow用户
提问于 2019-01-02 10:45:42
回答 1查看 66关注 0票数 1

我有一些与彼此有关的实体。

代码语言:javascript
复制
Answer
  - AnswerGroup
AnswerGroup
Condition
  - Question
Notion
Question
  - AnswerGroup
  - Theme
  - Notion
Theme

Php表示:

代码语言:javascript
复制
$entities = [
    ['name' => 'Answer', 'relations' => ['AnswerGroup']],
    ['name' => 'AnswerGroup', 'relations' => []],
    ['name' => 'Condition', 'relations' => ['Question']],
    ['name' => 'Notion', 'relations' => []],
    ['name' => 'Question', 'relations' => ['Theme', 'AnswerGroup', 'Notion']],
    ['name' => 'Theme', 'relations' => []],
];

我需要对它们进行排序,以便将依赖项放在第一位。以下是我期待的结果:

代码语言:javascript
复制
array:6 [
  0 => "AnswerGroup"
  1 => "Answer"
  2 => "Notion"
  3 => "Theme"
  4 => "Question"
  5 => "Condition"
]

我很天真,虽然我可以像这样简单地使用usort

代码语言:javascript
复制
usort($entities, function ($entityA, $entityB) {
    if (in_array($entityB, $entityA['relations'])) {
        return 1;
    }
    if (in_array($entityA, $entityB['relations'])) {
        return -1;
    }
    return 0;
});

但是:

代码语言:javascript
复制
dump(array_column($entities ,'name'));

给出

代码语言:javascript
复制
array:6 [
  0 => "Answer"
  1 => "AnswerGroup"
  2 => "Condition"
  3 => "Notion"
  4 => "Question"
  5 => "Theme"
]

我怎样才能订购我的实体?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-02 11:43:08

这是做你想做的事的一种方式。它使用一个递归函数列出每个实体的所有依赖项(关系)。每个实体的关系列表在处理前进行排序,以便按字母顺序得到每个级别关系的结果。最后,array_unique用于删除重复条目(例如,AnswerGroupAnswerQuestion的关系)。

代码语言:javascript
复制
function list_dependents($entity, $entities) {
    $sorted = array();
    sort($entity['relations']);
    foreach ($entity['relations'] as $r) {
        $sorted = array_merge($sorted, list_dependents($entities[array_search($r, array_column($entities, 'name'))], $entities));
    }
    $sorted = array_merge($sorted, array($entity['name']));
    return $sorted;
}
$sorted = array();
foreach ($entities as $entity) {
    $sorted = array_merge($sorted, list_dependents($entity, $entities));
}
$sorted = array_values(array_unique($sorted));
print_r($sorted);

输出:

代码语言:javascript
复制
Array (
    [0] => AnswerGroup
    [1] => Answer
    [2] => Notion
    [3] => Theme
    [4] => Question
    [5] => Condition 
)

基于3v4l.org的演示

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54004930

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档