我有以下树:
digraph G {
subgraph cluster0{
37[label="+"];
42[label="a"];
44[label="b"];
47[label="*"];
46[label="c"];
49[label="d"];
51[label="e"];
53[label="f"];
55[label="g"];
57[label="h"];
61[label="*"];
60[label="i"];
63[label="j"];
37 -> 42[label="c"];
37 -> 44[label="c"];
37 -> 47[label="c"];
37 -> 61[label="c"];
42 -> 37[label="p"];
44 -> 37[label="p"];
47 -> 37[label="p"];
47 -> 46[label="c"];
47 -> 49[label="c"];
47 -> 51[label="c"];
47 -> 53[label="c"];
47 -> 55[label="c"];
47 -> 57[label="c"];
46 -> 47[label="p"];
49 -> 47[label="p"];
51 -> 47[label="p"];
53 -> 47[label="p"];
55 -> 47[label="p"];
57 -> 47[label="p"];
61 -> 37[label="p"];
61 -> 60[label="c"];
61 -> 63[label="c"];
60 -> 61[label="p"];
63 -> 61[label="p"];
}
}
输出在这里:http://i.imgur.com/q1qXkCT.png
第一个*
子树中的子项顺序为:G H C D E F
,但应为C D E F G H
。
我注意到如果我删除subgraph cluster0{
订单是正确的,但我不能这样做。
你能建议任何其他解决方案吗?
答案 0 :(得分:0)
Graphviz尝试在没有其他约束时保留节点的词法排序。但是,边缘标签可能会影响放置,因为它们占用空间并可以推动节点。
如果您有特定的订单,那么请尝试类似
的订单{ rank = same;
46 -> 49 -> 51 -> 53 -> 55 -> 57 [style = invis];
}
将额外的排序约束引入图中。
你需要小心这一点,因为它可能以非常难以预测的方式扭曲更复杂的图形。