当前位置: 首页>>代码示例>>C#>>正文


C# SortedSet.Collapse方法代码示例

本文整理汇总了C#中SortedSet.Collapse方法的典型用法代码示例。如果您正苦于以下问题:C# SortedSet.Collapse方法的具体用法?C# SortedSet.Collapse怎么用?C# SortedSet.Collapse使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SortedSet的用法示例。


在下文中一共展示了SortedSet.Collapse方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: FindFirstSynonym

        public static String FindFirstSynonym(this IEnumerable<Node> tree, String path)
        {
            Contract.Requires(tree != null, String.Format(_mask, "tree"));
            Contract.Requires(path != null, String.Format(_mask, "path"));
            Contract.Requires(path.Contains("|"), "Doesn't support combinatorials yet");

            var result = "Synonym not found";
            var other  = path.BuildTree();

            var depth = other.Max(n => n.Item1);
            var node  = other.First(n => n.Item1 == depth);

            var children = tree.Where(n => n.Item2 == node.Item3);
            var potentialSynonyms = tree.Where(n => n.Item3 == children.First().Item3);

            var maybeSynonyms = potentialSynonyms.Where(n => n.Item2 != node.Item3)
                                                 .Select(n => n);

            var childrenSet = new SortedSet<String>(children.Select(n => n.Item3));
            foreach (var item in maybeSynonyms)
            {
                var otherChildren = tree.Where(n => n.Item2 == item.Item2)
                                        .Select(o => o.Item3);
                var otherChildrenSet = new SortedSet<String>(otherChildren);

                if (otherChildrenSet.SequenceEqual(childrenSet))
                {
                    var miniTree = new SortedSet<Node>();
                    miniTree.Add(Tuple.Create(0, String.Empty, "home"));
                    miniTree.Add(Tuple.Create(item.Item1 - 1, "home", item.Item2));
                    result = miniTree.Collapse();
                    break;
                }
            }

            return result;
        }
开发者ID:ciriarte,项目名称:playing-with-permutations,代码行数:37,代码来源:TreeExtensions.cs


注:本文中的SortedSet.Collapse方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。