公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

+2 投票
1.9k 浏览

有一个列表list

list = {{1, 2}, {1, 3}, {2, 3}, {2, 4}, {3, 1}, {3, 4}}

目前是这么找的,结果有三个回环的组合,但感觉那个Select的criterion写得很累赘

Select[Permutations[
  list, {3}], #[[1, 2]] == #[[2, 1]] && #[[2, 2]] == #[[3, 
      1]] && #[[3, 2]] == #[[1, 1]] &]

结果

{{{1, 2}, {2, 3}, {3, 1}}, {{2, 3}, {3, 1}, {1, 2}}, {{3, 1}, {1, 
   2}, {2, 3}}}

 

用户: Lozmlve*永 (1.2k 分)

2 个回答

+2 投票
 
已采纳

有。(*凑12字符专用*)

补充:

Select[ConnectedComponents[Rule @@@ list], Length@# == 3 &]

二次补充:

data = {{1, 3}, {1, 5}, {1, 5}, {2, 4}, {2, 6}, {3, 5}, {4, 6}};
g = Graph[UndirectedEdge @@@ data, VertexLabels -> "Name"];
ConnectedComponents@g
FindCycle@g

ConnectedComponents和FindCycle存在较大的差异,所以实际选择中需要根据是否有向、“回环”的定义等具体情况进行考虑。

用户: 苹果 (2.2k 分)
采纳于 用户:Lozmlve*永
我竟无言以对~~~~~~~
这补充有意思。(*凑12字符专用*)
愁。回答还是12字限制,评论改成6字限制了。
+1 投票
FindCycle[Graph[DirectedEdge @@@ list], {3}, All]

其实感觉弄成Graph输出就挺直观的,如果需要给出的那种输出格式可以转换:

Table[RotateLeft[#, i], {i, 0, 2}] & /@ % /. DirectedEdge -> List

用户: happyfish (1.8k 分)
...