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


C# NTree类代码示例

本文整理汇总了C#中NTree的典型用法代码示例。如果您正苦于以下问题:C# NTree类的具体用法?C# NTree怎么用?C# NTree使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


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

示例1: NTreeDeletesByIndexIndividualUnique

        public void NTreeDeletesByIndexIndividualUnique()
        {
            var objs = TestResourceFactory.GetMockClassAObjects(50).ToList();

            var seedIndex = new Seed32();
            var seedSegment = new Seed64();

            objs.ForEach(o => o.Id = seedIndex.Increment());

            using (var tree = new NTree<int, MockClassA, long>("Id", true))
            {
                foreach (var o in objs)
                    tree.AddOrUpdate(new Tuple<MockClassA, long>(o, seedSegment.Increment()));

                Assert.AreEqual(50, tree.Length);

                Assert.AreEqual(5, tree.GetFirstByIndex(5));
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
                Assert.AreEqual(1, tree.GetByIndex(5).Count());

                Assert.AreEqual(1, tree.Delete(5).Length);

                Assert.AreEqual(50, tree.Length);

                Assert.AreEqual(0, tree.GetFirstByIndex(5));
            }
        }
开发者ID:thehexgod,项目名称:BESSY-DB,代码行数:27,代码来源:NTreeDeleteTests.cs

示例2: NTreeChecksAllWithLargeCount

        public void NTreeChecksAllWithLargeCount()
        {
            using (var tree = new NTree<int, MockClassA, long>("Id", true))
            {
                var objs = new List<MockClassA>();
                var seedIndex = new Seed32();
                var seedSegment = new Seed64();

                for (var i = 0; i < 5; i++)
                {
                    var additions = TestResourceFactory.GetMockClassAObjects(100000).ToList();

                    additions.ForEach(o => o.Id = seedIndex.Increment());

                    tree.AddOrUpdateRange(additions.Select(o => new Tuple<MockClassA, long>(o, seedSegment.Increment())).ToList());
                }

                Assert.AreEqual(500000, tree.Length);

                Assert.AreEqual(5, tree.GetFirstByIndex(5));
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
                Assert.AreEqual(1, tree.GetByIndex(5).Count());

                tree.AddOrUpdate(new Tuple<MockClassA, long>(TestResourceFactory.CreateRandom().WithId(seedIndex.Increment()), seedSegment.Increment()));

                Assert.AreEqual(500001, tree.Length);

                tree.AddOrUpdateRange(
                    tree.AsEnumerable().First().Take(100)
                    .Select(s => new NTreeItem<int, long>(s.Item2.Index, s.Item2.Segment))
                    .ToList());

                Assert.AreEqual(500001, tree.Length);
            }
        }
开发者ID:thehexgod,项目名称:BESSY-DB,代码行数:35,代码来源:NTreeUniqueTests.cs

示例3: NTreeFetchesByIndexRange

        public void NTreeFetchesByIndexRange()
        {
            var objs = TestResourceFactory.GetMockClassAObjects(5000).ToList();

            var seedIndex = new Seed32();
            var seedSegment = new Seed64();

            objs.ForEach(o => o.Id = seedIndex.Increment());
            var toAdd = objs.Select(o => new Tuple<MockClassA, long>(o, seedSegment.Increment())).ToList();

            using (var tree = new NTree<int, MockClassA, long>("Id"))
            {
                var ids = tree.AddOrUpdateRange(toAdd);

                Assert.AreEqual(5000, tree.Length);

                Assert.AreEqual(5, tree.GetFirstByIndex(5));
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
                Assert.AreEqual(1, tree.GetByIndex(5).Count());

                tree.AddOrUpdate(new Tuple<MockClassA, long>(TestResourceFactory.CreateRandom().WithId(seedIndex.Increment()), seedSegment.Increment()));

                Assert.AreEqual(5001, tree.Length);

                long[] loc;
                var range = tree.GetByIndexRangeInclusive(51, 250, out loc);

                Assert.AreEqual(200, range.Length);
            }
        }
开发者ID:thehexgod,项目名称:BESSY-DB,代码行数:30,代码来源:NTreeNonUniqueTests.cs

示例4: AddToFrontier

 private bool AddToFrontier(NTree<PuzzleNode> nodeState)
 {
     if (!ClosedList.Contains(nodeState) || !Frontier.Contains(nodeState))
     {
         Frontier.Enqueue(nodeState);
         return true;
     }
     return false;
 }
开发者ID:joshkoz,项目名称:Searcher,代码行数:9,代码来源:BFSStrategy.cs

示例5: PathToNode

        /// <summary>
        /// Find the path to the partular node in the tree from the root node in the tree.
        /// Returns an array of 'Direction's.
        /// </summary>
        /// <param name="puzzle"></param>
        /// <returns></returns>
        public Direction[] PathToNode(NTree<PuzzleNode> puzzle)
        {
            Direction[] result;

            if (puzzle.Parent == null) //If this is the root node, there is no path!
            {
                result = new Direction[0];
                return result;
            }
            else                //Other wise, path to here is the path to parent
                                // plus parent to here
            {
                Direction[] pathToParent = PathToNode(puzzle.Parent);
                result = new Direction[pathToParent.Length + 1];
                for (int i = 0; i < pathToParent.Length; i++)
                {
                    result[i] = pathToParent[i];
                }
                result[result.Length - 1] = puzzle.Value.PathFromParent;
                return result;
            }
        }
开发者ID:joshkoz,项目名称:Searcher,代码行数:28,代码来源:TreeVisitor.cs

示例6: NTreePushesEntities

        public void NTreePushesEntities()
        {
            var objs = TestResourceFactory.GetMockClassAObjects(50).ToList();

            var seedIndex = new Seed32();
            var seedSegment = new Seed64();

            objs.ForEach(o => o.Id = seedIndex.Increment());
            var toAdd = objs.Select(o => new Tuple<MockClassA, long>(o, seedSegment.Increment())).ToList();

            using (var tree = new NTree<int, MockClassA, long>("Id", true))
            {
                var ids = tree.AddOrUpdateRange(toAdd);
                tree.AddOrUpdate(toAdd.First());

                Assert.AreEqual(50, tree.Length);

                Assert.AreEqual(5L, tree.GetFirstByIndex(5));
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
                Assert.AreEqual(1, tree.GetByIndex(1).Count());
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
            }
        }
开发者ID:thehexgod,项目名称:BESSY-DB,代码行数:23,代码来源:NTreeUniqueTests.cs

示例7: SearchPagesInPortalGroupInternal

        private NTree<ItemDto> SearchPagesInPortalGroupInternal(string treeAsJson, string searchText, int sortOrder)
        {
            var treeNode = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };
            var openedNode = Json.Deserialize<NTree<ItemIdDto>>(treeAsJson);
            if (openedNode == null)
            {
                return treeNode;
            }

            var portals = GetPortalGroup(sortOrder);
            treeNode.Children = portals.Select(dto => new NTree<ItemDto> { Data = dto }).ToList();

            if (!openedNode.HasChildren())
            {
                return treeNode;
            }
            foreach (var openedNodeChild in openedNode.Children)
            {
                var portalIdString = openedNodeChild.Data.Id;
                var treeNodeChild = treeNode.Children.Find(child => String.Equals(child.Data.Key, portalIdString, StringComparison.InvariantCultureIgnoreCase));
                if (treeNodeChild == null)
                {
                    continue;
                }
                int portalId;
                if (int.TryParse(treeNodeChild.Data.Key.Replace(PortalPrefix, string.Empty), out portalId))
                {
                    var pageTree = SearchPagesInternal(portalId, searchText, sortOrder);
                    treeNodeChild.Children = pageTree.Children;
                }
            }
            return treeNode;
        }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:33,代码来源:ItemListServiceController.cs

示例8: SortPagesInternal

 private NTree<ItemDto> SortPagesInternal(int portalId, NTree<ItemIdDto> openedNodesTree, int sortOrder)
 {
     var pages = GetPortalPages(portalId);
     var sortedTree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };
     if (pages == null)
     {
         return sortedTree;
     }
     SortPagesRecursevely(pages, sortedTree, openedNodesTree, sortOrder);
     return sortedTree;
 }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:11,代码来源:ItemListServiceController.cs

示例9: SearchPagesInternal

        private NTree<ItemDto> SearchPagesInternal(int portalId, string searchText, int sortOrder)
        {
            var tree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };

            List<TabInfo> tabs;
            if (portalId == -1)
            {
                portalId = GetActivePortalId();
            }
            else
            {
                if (!IsPortalIdValid(portalId))
                {
                    return tree;
                }
            }

            Func<TabInfo, bool> searchFunc;
            if (String.IsNullOrEmpty(searchText))
            {
                searchFunc = page => true;
            }
            else
            {
                searchFunc = page => page.LocalizedTabName.IndexOf(searchText, StringComparison.InvariantCultureIgnoreCase) > -1;
            }

            var tabController = new TabController();
            var allTabs = tabController.GetAllTabs().ToArray().Select(tab => (TabInfo)tab).ToList();

            if (portalId > -1)
            {
                var includeHiddenTabs = PortalSettings.UserInfo.IsSuperUser || PortalSettings.UserInfo.IsInRole("Administrators");
               
                if (!includeHiddenTabs) allTabs = allTabs.Where(t => t.IsVisible).ToList();
                tabs = allTabs.Where(tab => tab.PortalID == portalId && !tab.DisableLink && searchFunc(tab))
                    .OrderBy(tab => tab.TabOrder)
                    .ToList();
            }
            else
            {
                if (PortalSettings.UserInfo.IsSuperUser)
                {
                    tabs = allTabs.Where(tab => tab.PortalID == -1 && !tab.DisableLink && searchFunc(tab))
                    .OrderBy(tab => tab.TabOrder)
                    .ToList();
                }
                else
                {
                    return tree;
                }
            }

            var pages = tabs.Select(tab => new ItemDto
                {
                    Key = tab.TabID.ToString(CultureInfo.InvariantCulture),
                    Value = tab.LocalizedTabName,
                    HasChildren = false,
                    Selectable = true
                });

            tree.Children = ApplySort(pages, sortOrder).Select(dto => new NTree<ItemDto> { Data = dto }).ToList();
            return tree;
        }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:64,代码来源:ItemListServiceController.cs

示例10: ExonChaining

 /// <summary>
 /// 
 /// </summary>
 /// <param name="graph"></param>
 /// <param name="k">number of intervals</param>
 /// <returns></returns>
 public IEnumerable<int> ExonChaining(NTree<string> graph, int k) 
 {
     return null;
 }
开发者ID:dancingplatypus,项目名称:GeneticAlgorithms.Net,代码行数:10,代码来源:TestSplicedAlignment.cs

示例11: GetTreePathForFolderInternal

        private NTree<ItemDto> GetTreePathForFolderInternal(string selectedItemId, int sortOrder, string permission)
        {
            var tree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };

            int itemId;
            if (string.IsNullOrEmpty(selectedItemId) || !int.TryParse(selectedItemId, out itemId))
            {
                return tree;
            }

            if (itemId <= 0)
            {
                return tree;
            }

            var folder = FolderManager.Instance.GetFolder(itemId);
            if (folder == null)
            {
                return tree;
            }

            var hasPermission = string.IsNullOrEmpty(permission) ?
                (HasPermission(folder, "BROWSE") || HasPermission(folder, "READ")) :
                HasPermission(folder, permission.ToUpper());
            if (!hasPermission) return new NTree<ItemDto>();

            var selfTree = new NTree<ItemDto> { Data = new ItemDto
                {
                    Key = folder.FolderID.ToString(CultureInfo.InvariantCulture), 
                    Value = folder.FolderName, 
                    HasChildren = HasChildren(folder, permission),
                    Selectable = true
                } };
            var parentId = folder.ParentID;
            var parentFolder = parentId > 0 ? FolderManager.Instance.GetFolder(parentId) : null;

            while (parentFolder != null)
            {
                // load all sibling
                var siblingFolders = GetFolderDescendants(parentFolder, string.Empty, permission)
                    .Select(folderInfo => new ItemDto
                        {
                            Key = folderInfo.FolderID.ToString(CultureInfo.InvariantCulture), 
                            Value = folderInfo.FolderName, 
                            HasChildren = HasChildren(folderInfo, permission),
                            Selectable = true
                        }).ToList();
                siblingFolders = ApplySort(siblingFolders, sortOrder).ToList();

                var siblingFoldersTree = siblingFolders.Select(f => new NTree<ItemDto> { Data = f }).ToList();

                // attach the tree
                if (selfTree.Children != null)
                {
                    foreach (var node in siblingFoldersTree)
                    {
                        if (node.Data.Key == selfTree.Data.Key)
                        {
                            node.Children = selfTree.Children;
                            break;
                        }
                    }
                }

                selfTree = new NTree<ItemDto> { Data = new ItemDto
                    {
                        Key = parentId.ToString(CultureInfo.InvariantCulture),
                        Value = parentFolder.FolderName,
                        HasChildren = true,
                        Selectable = true
                    }, Children = siblingFoldersTree
                };

                parentId = parentFolder.ParentID;
                parentFolder = parentId > 0 ? FolderManager.Instance.GetFolder(parentId) : null;
            }
            selfTree.Data.Value = SharedConstants.RootFolder;

            tree.Children.Add(selfTree);
            return tree;
        }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:81,代码来源:ItemListServiceController.cs

示例12: NTreePushesLotsOfDuplicateEntities

        public void NTreePushesLotsOfDuplicateEntities()
        {
            var objs = TestResourceFactory.GetMockClassAObjects(20480).ToList();

            var seedIndex = new Seed32();
            var seedSegment = new Seed64();

            objs.ForEach(o => o.Id = seedIndex.Increment());
            var toAdd = objs.Select(o => new Tuple<MockClassA, long>(o, seedSegment.Increment())).ToList();

            using (var tree = new NTree<int, MockClassA, long>("Id", true))
            {
                var ids = tree.AddOrUpdateRange(toAdd);

                Assert.AreEqual(20480, tree.Length);

                Assert.AreEqual(5, tree.GetFirstByIndex(5));
                Assert.AreEqual(5, tree.GetFirstBySegment(5));
                Assert.AreEqual(1, tree.GetByIndex(5).Count());

                tree.AddOrUpdate(new Tuple<MockClassA, long>(TestResourceFactory.CreateRandom().WithId(seedIndex.Increment()), seedSegment.Increment()));

                Assert.AreEqual(20481, tree.Length);

                tree.AddOrUpdateRange(toAdd.Skip(100).Take(100).ToList());

                Assert.AreEqual(20481, tree.Length);
            }
        }
开发者ID:thehexgod,项目名称:BESSY-DB,代码行数:29,代码来源:NTreeUniqueTests.cs

示例13: GetFoldersInternal

 private NTree<ItemDto> GetFoldersInternal(int portalId, int sortOrder, string permissions)
 {
     var tree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };
     var children = ApplySort(GetFolderDescendantsInternal(portalId, -1, sortOrder, string.Empty, permissions), sortOrder).Select(dto => new NTree<ItemDto> { Data = dto }).ToList();
     tree.Children = children;
     foreach (var child in tree.Children)
     {
         children = ApplySort(GetFolderDescendantsInternal(portalId, child.Data.Key, sortOrder, string.Empty, permissions), sortOrder).Select(dto => new NTree<ItemDto> { Data = dto }).ToList();
         child.Children = children;
     }
     return tree;
 }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:12,代码来源:ItemListServiceController.cs

示例14: GetTreePathForPageInternal

 private NTree<ItemDto> GetTreePathForPageInternal(string itemId, int sortOrder, bool includePortalTree = false)
 {
     var tree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };
     int itemIdAsInt;
     if (string.IsNullOrEmpty(itemId) || !int.TryParse(itemId, out itemIdAsInt))
     {
         return tree;
     }
     var portals = PortalController.GetPortalDictionary();
     int portalId;
     if (portals.ContainsKey(itemIdAsInt))
     {
         portalId = portals[itemIdAsInt];
     }
     else
     {
         return tree;
     }
     return GetTreePathForPageInternal(portalId, itemIdAsInt, sortOrder, includePortalTree);
 }
开发者ID:ryanmalone,项目名称:BGDNNWEB,代码行数:20,代码来源:ItemListServiceController.cs

示例15: SearchPagesInternal

        private NTree<ItemDto> SearchPagesInternal(int portalId, string searchText, int sortOrder, bool includeDisabled = false, bool includeAllTypes = false, bool includeActive = true, bool includeHostPages = false)
        {
            var tree = new NTree<ItemDto> { Data = new ItemDto { Key = RootKey } };

            List<TabInfo> tabs;
            if (portalId == -1)
            {
                portalId = GetActivePortalId();
            }
            else
            {
                if (!IsPortalIdValid(portalId))
                {
                    return tree;
                }
            }

            Func<TabInfo, bool> searchFunc;
            if (String.IsNullOrEmpty(searchText))
            {
                searchFunc = page => true;
            }
            else
            {
                searchFunc = page => page.LocalizedTabName.IndexOf(searchText, StringComparison.InvariantCultureIgnoreCase) > -1;
            }

            if (portalId > -1)
            {
                var includeHiddenTabs = PortalSettings.UserInfo.IsSuperUser || PortalSettings.UserInfo.IsInRole("Administrators");

                tabs = TabController.Instance.GetTabsByPortal(portalId).Where(tab =>
                                        (includeActive || tab.Value.TabID != PortalSettings.ActiveTab.TabID)
                                        && (includeHiddenTabs || tab.Value.IsVisible)
                                        && (includeDisabled || !tab.Value.DisableLink) 
                                        && (includeAllTypes || tab.Value.TabType == TabType.Normal) 
                                        && searchFunc(tab.Value))
                    .OrderBy(tab => tab.Value.TabOrder)
                    .Select(tab => tab.Value)
                    .ToList();

                if (PortalSettings.UserInfo.IsSuperUser && includeHostPages)
                {
                    tabs.AddRange(TabController.Instance.GetTabsByPortal(-1).Where(tab => !tab.Value.DisableLink && searchFunc(tab.Value))
                    .OrderBy(tab => tab.Value.TabOrder)
                    .Select(tab => tab.Value)
                    .ToList());
                }
            }
            else
            {
                if (PortalSettings.UserInfo.IsSuperUser)
                {
                    tabs = TabController.Instance.GetTabsByPortal(-1).Where(tab => !tab.Value.DisableLink && searchFunc(tab.Value))
                    .OrderBy(tab => tab.Value.TabOrder)
                    .Select(tab => tab.Value)
                    .ToList();
                }
                else
                {
                    return tree;
                }
            }

            var pages = tabs.Select(tab => new ItemDto
            {
                Key = tab.TabID.ToString(CultureInfo.InvariantCulture),
                Value = tab.LocalizedTabName,
                HasChildren = false,
                Selectable = true
            });

            tree.Children = ApplySort(pages, sortOrder).Select(dto => new NTree<ItemDto> { Data = dto }).ToList();
            return tree;
        }
开发者ID:revellado,项目名称:privateSocialGroups,代码行数:75,代码来源:ItemListServiceController.cs


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