这是我想要创建的graphviz有向图的代码。这个创建的示例图像在下面,我想用'e'切换节点'a',我需要用'd'切换节点'b'。我试过改变他们在代码和其他东西中的位置。我现在拥有的和我想要的例子在下面的链接中。
digraph {
graph[nodesep=1.75, ranksep=1.25, pad=".5", rankdir=LR];
node[shape=circle];
F[label=f];
A[label=a];
E[label=e];
B[label=b];
D[label=d];
C[label=c];
{rank=min; F};
{rank=same; A; E};
{rank=same; B; D};
{rank=max; C};
F -> {D};
A -> {B D F};
E -> {D F};
B -> {C F};
D -> {B};
C -> {D};
}
答案 0 :(得分:1)
我对这个实现非常接近,尽管仍然很难将E与D水平对齐。但是这个方案按照您指定的顺序获取节点,使用不可见的方向链接根据排名强制执行顺序。
digraph {
rankdir=LR;
node[shape=circle];
nodesep=1.75; ranksep=1.25; pad=0.5;
{rank=same; rank=min; F; }
{rank = same; A -> E [style=invis]; }
{rank= same; B -> D [style=invis]; }
{rank=same; rank=max; C;}
F[label=f];
A[label=a];
E[label=e];
B[label=b];
D[label=d];
C[label=c];
A -> B;
A -> D;
A-> F;
B-> C;
B-> F;
C-> D;
D-> B;
F-> D;
nodesep=0.75;
E -> D;
E-> F;
}
答案 1 :(得分:1)
我纠正了上面的代码并结合@JLH答案解决了我自己的问题。
digraph {
graph[nodesep=1, ranksep=1, pad=".5"];
rankdir="LR";
node[shape=circle];
F[label=f];
A[label=a];
E[label=e];
B[label=b];
D[label=d];
C[label=c];
{rank=min; F};
{rank=same; A E}
{rank=same; B D}
{rank=max; C};
F -> {D};
A -> {B D F};
E -> {D F};
B -> {C F}
D -> {B};
C -> {D};
edge[style=invis];
A -> E
E -> B
B -> D
}
答案的关键是在E和B之间添加一个不可见的连接,将E拉回到循环中。