如何解决如何使用igraph查找所有下属
我只是想知道是否有办法找到经理的所有下属。在下面的例子中,p2 中的人向 P1 中的人报告。我想找到所有向 A 报告的人。如果我使用下面的代码,我可以得到 A->B A->C。但我想要的是 A->B A->C A->D。可能吗?
d <- data.frame(p1=c('A','A','C'),p2=c('B','C','D'))
library(igraph)
g <- graph.data.frame(d,directed=T)
print(g,e=TRUE,v=TRUE)
E(g)[from(V(g)["A"])]
解决方法
rstudio.com 上的 joels 提供了一个很好的回答来解决您的问题:https://community.rstudio.com/t/finding-all-combinations-of-parent-child-ids/24666/2
我在下面复制了乔尔斯的代码:
library(tidyverse)
library(igraph)
d <- data.frame(p1=c('A','A','C'),p2=c('B','C','D'))
df_g <- graph.data.frame(d,directed=T)
wanted_df = map(V(df_g),~ names(subcomponent(df_g,.x,mode="out"))) %>%
# Convert the list output to a data frame
map_df(~data.frame(cid=.x),.id="pid") %>%
# Get rid of rows where `pid` and `cid` are equal
filter(pid != cid) %>%
filter(pid=="A")
> print(wanted_df)
pid cid
1 A C
2 A B
3 A D
,
也许下面的代码可以回答这个问题。
h <- all_simple_paths(
g,from = "A",to = V(g),mode = "out"
)
if(any(lengths(h) > 2)){
h <- lapply(h,function(x) x[c(1,length(x))])
}
h
#[[1]]
#+ 2/4 vertices,named,from 17f23ba:
#[1] A C
#
#[[2]]
#+ 2/4 vertices,from 17f23ba:
#[1] A D
#
#[[3]]
#+ 2/4 vertices,from 17f23ba:
#[1] A B
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。