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


C# Set.Insert方法代码示例

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


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

示例1: Edges

 IEnumerable<PointPair> Edges() {
     var set = new Set<PointPair>();
     foreach (var poly in Polylines)
         for (var pp = poly.StartPoint; pp.Next != null; pp = pp.Next)
             set.Insert(FlipCollapser.OrderedPair(pp));
     return set;
 }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:7,代码来源:PathFixer.cs

示例2: SwitchFlips

 void SwitchFlips() {
     var queued = new Set<Polyline>(Polylines);
     var queue = new Queue<Polyline>();
     foreach (Polyline e in Polylines)
         queue.Enqueue(e);
     while (queue.Count > 0) {
         Polyline initialPolyline = queue.Dequeue();
         queued.Remove(initialPolyline);
         Polyline changedPolyline = ProcessPolyline(initialPolyline);
         if (changedPolyline != null) {
             //we changed both polylines
             if (!queued.Contains(initialPolyline)) {
                 queued.Insert(initialPolyline);
                 queue.Enqueue(initialPolyline);
             }
             if (!queued.Contains(changedPolyline)) {
                 queued.Insert(changedPolyline);
                 queue.Enqueue(changedPolyline);
             }
         }
     }
 }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:22,代码来源:FlipSwitcher.cs

示例3: EdgePassport

        /// <summary>
        ///  The set of shapes where the edgeGeometry source and target ports shapes are citizens.
        ///  In the simple case it is the union of the target port shape parents and the sourceport shape parents.
        ///  When one end shape contains another, the passport is the set consisting of the end shape and all other shape parents.
        /// </summary>
        /// <param name="edge"></param>
        /// <returns></returns>
        Set<Shape> EdgePassport(Edge edge) {
            EdgeGeometry edgeGeometry = edge.EdgeGeometry;
            var ret = new Set<Shape>();
            var sourceShape = portsToShapes[edgeGeometry.SourcePort];
            var targetShape = portsToShapes[edgeGeometry.TargetPort];

            if (IsAncestor(sourceShape, targetShape)) {
                ret.InsertRange(targetShape.Parents);
                ret.Insert(sourceShape);
                return ret;
            }
            if (IsAncestor(targetShape, sourceShape)) {
                ret.InsertRange(sourceShape.Parents);
                ret.Insert(targetShape);
                return ret;
            }

            if (sourceShape != looseRoot)
                ret.InsertRange(sourceShape.Parents);

            if (targetShape != looseRoot)
                ret.InsertRange(targetShape.Parents);

            return ret;
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:32,代码来源:SplineRouter.cs

示例4: chromatogramListForm_CellClick

        void chromatogramListForm_CellClick( object sender, ChromatogramListCellClickEventArgs e )
        {
            if( e.Chromatogram == null || e.Button != MouseButtons.Right )
                return;

            ChromatogramListForm chromatogramListForm = sender as ChromatogramListForm;

            List<GraphItem> selectedGraphItems = new List<GraphItem>();
            Set<int> selectedRows = new Set<int>();
            foreach( DataGridViewCell cell in chromatogramListForm.GridView.SelectedCells )
            {
                if( selectedRows.Insert( cell.RowIndex ).WasInserted )
                    selectedGraphItems.Add( chromatogramListForm.GetChromatogram( cell.RowIndex ) as GraphItem );
            }

            if( selectedRows.Count == 0 )
                chromatogramListForm.GridView[e.ColumnIndex, e.RowIndex].Selected = true;

            ContextMenuStrip menu = new ContextMenuStrip();
            if( CurrentGraphForm != null )
            {
                if( selectedRows.Count == 1 )
                {
                    menu.Items.Add( "Show as Current Graph", null, new EventHandler( graphListForm_showAsCurrentGraph ) );
                    menu.Items.Add( "Overlay on Current Graph", null, new EventHandler( graphListForm_overlayOnCurrentGraph ) );
                    menu.Items.Add( "Stack on Current Graph", null, new EventHandler( graphListForm_stackOnCurrentGraph ) );
                } else
                {
                    menu.Items.Add( "Overlay All on Current Graph", null, new EventHandler( graphListForm_overlayAllOnCurrentGraph ) );
                    menu.Items.Add( "Stack All on Current Graph", null, new EventHandler( graphListForm_showAllAsStackOnCurrentGraph ) );
                }
            }

            if( selectedRows.Count == 1 )
            {
                menu.Items.Add( "Show as New Graph", null, new EventHandler( graphListForm_showAsNewGraph ) );
                menu.Items.Add( "Show Table of Data Points", null, new EventHandler( graphListForm_showTableOfDataPoints ) );
                menu.Items[0].Font = new Font( menu.Items[0].Font, FontStyle.Bold );
                menu.Tag = e.Chromatogram;
            } else
            {
                menu.Items.Add( "Show All as New Graphs", null, new EventHandler( graphListForm_showAllAsNewGraph ) );
                menu.Items.Add( "Overlay All on New Graph", null, new EventHandler( graphListForm_overlayAllOnNewGraph ) );
                menu.Items.Add( "Stack All on New Graph", null, new EventHandler( graphListForm_showAllAsStackOnNewGraph ) );
                menu.Tag = selectedGraphItems;
            }

            menu.Show( Form.MousePosition );
        }
开发者ID:AlexandreBurel,项目名称:pwiz-mzdb,代码行数:49,代码来源:Manager.cs

示例5: MapClustersToIds

 void MapClustersToIds(Cluster cluster) {
     string id;
     var setOfIds = new Set<string>(nodeIds.Values);
     foreach (Cluster child in cluster.AllClustersDepthFirst()) {
         if (!nodeIds.TryGetValue(child, out id)) {
             id = FindNewId(setOfIds);
             nodeIds[child] = id;
             setOfIds.Insert(id);
         }
     }
 }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:11,代码来源:GeometryGraphWriter.cs

示例6: OGraphChanged

        /// <summary>
        /// oGraph has changed too
        /// </summary>
        void OGraphChanged()
        {
            var vDrawingEdges = new Set<DrawingEdge>();
            var vDrawingNodes = new Set<DrawingNode>();
            foreach (var dro in drawingObjectsToIViewerObjects.Keys) {
                var n = dro as DrawingNode;
                if (n != null)
                    vDrawingNodes.Insert(n);
                else {
                    var edge = dro as DrawingEdge;
                    if (edge != null)
                        vDrawingEdges.Insert((DrawingEdge) dro);
                }
            }
            var oDrawgingEdges = new Set<DrawingEdge>();
            var oDrawingNodes = new Set<DrawingNode>();
            var oGraph = ((LgLayoutSettings) Graph.LayoutAlgorithmSettings).OGraph;
            foreach (var node in oGraph.Nodes)
                oDrawingNodes.Insert((DrawingNode) node.UserData);
            foreach (var edge in oGraph.Edges)
                oDrawgingEdges.Insert((DrawingEdge) edge.UserData);

            ProcessRemovalsForLg(vDrawingNodes - oDrawingNodes, vDrawingEdges - oDrawgingEdges);
            ProcessAdditions(oDrawingNodes - vDrawingNodes, oDrawgingEdges - vDrawingEdges);
            //    TestCorrectness(oGraph, oDrawingNodes, oDrawgingEdges);
            double pathThickness = GetBorderPathThickness();
            foreach (var viewerObject in Entities) {
                if (viewerObject is XNode)
                {
                    ((XNode)viewerObject).BorderPathThickness = pathThickness;
                }
                else if (viewerObject is XEdge)
                {
                    ((XEdge)viewerObject).StrokePathThickness = pathThickness / 2;
                }
                Invalidate(viewerObject);
            }
            SetBackgroundRectanglePositionAndSize(((LgLayoutSettings) drawingGraph.LayoutAlgorithmSettings).OGraph);
        }
开发者ID:mrkcass,项目名称:SuffixTreeExplorer,代码行数:42,代码来源:XGraphViewer.cs

示例7: MoveNodePositions

        /// <summary>
        /// Lets the tree grow according to the ideal distances.
        /// </summary>
        /// <param name="treeEdges"></param>
        /// <param name="nodePositions"></param>
        /// <param name="rootNodeId"></param>
        static void MoveNodePositions(List<Tuple<int, int, double, double, double>> treeEdges, Point[] nodePositions,
            int rootNodeId) {
            var posOld = (Point[]) nodePositions.Clone();

            var visited = new Set<int>();
            visited.Insert(rootNodeId);
            for (int i = 0; i < treeEdges.Count; i++) {
                var tupleEdge = treeEdges[i];
                if (visited.Contains(tupleEdge.Item1))
                    MoveUpperSite(tupleEdge, nodePositions, posOld, visited);
                else {
                    Debug.Assert(visited.Contains(tupleEdge.Item2));
                    MoveLowerSite(tupleEdge, nodePositions, posOld, visited);
                }
            }

        }
开发者ID:WenzCao,项目名称:automatic-graph-layout,代码行数:23,代码来源:OverlapRemoval.cs

示例8: UpdateRegionsForPossibleJumpersAndInsertJumpers

        /// <summary>
        /// some other jumpers may stop being ones if the jump 
        /// was just in to their destination layer, so before the actual 
        /// jump we have to recheck if the jump makes sense
        /// 
        /// </summary>
        /// <param name="jumperLayer">old layer of jumper</param>
        /// <param name="jumper"></param>
        void UpdateRegionsForPossibleJumpersAndInsertJumpers(int jumperLayer, int jumper) {
            Set<int> neighborPossibleJumpers = new Set<int>();
            //update possible jumpers neighbors
            foreach (int v in new Pred(dag, jumper))
                if (IsJumper(v)) {
                    this.CalculateRegionAndInsertJumper(v);
                    neighborPossibleJumpers.Insert(v);
                }

            foreach (int v in new Succ(dag, jumper))
                if (IsJumper(v)) {
                    this.CalculateRegionAndInsertJumper(v);
                    neighborPossibleJumpers.Insert(v);
                }

            List<int> possibleJumpersToUpdate = new List<int>();

            foreach (KeyValuePair<int, IntPair> kv in this.possibleJumperFeasibleIntervals) {
                if (!neighborPossibleJumpers.Contains(kv.Key))
                    if (kv.Value.x > jumperLayer && kv.Value.y < jumperLayer)
                        possibleJumpersToUpdate.Add(kv.Key);
            }

            foreach (int v in possibleJumpersToUpdate)
                this.CalculateRegionAndInsertJumper(v);
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:34,代码来源:Balancing.cs

示例9: CreatePregraphFromSetOfEdgeGeometries

        private PreGraph CreatePregraphFromSetOfEdgeGeometries(EdgeGeometry[] egs) {
            var nodeBoundaries = new Set<ICurve>();
            var eg = egs[0];
            var c = GetPortCurve(eg.SourcePort);
            var rect = c.BoundingBox;
            nodeBoundaries.Insert(c);
            nodeBoundaries.Insert(eg.TargetPort.Curve);
            rect.Add(eg.TargetPort.Curve.BoundingBox);
            var overlapped = nodeTree.GetNodeItemsIntersectingRectangle(rect);
            foreach (var nodeBoundary in overlapped)
                nodeBoundaries.Insert(nodeBoundary);

            return new PreGraph(egs, nodeBoundaries);
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:14,代码来源:MultiEdgeRouter.cs

示例10: ThreadBoneEdgeThroughCdt

        Set<CdtEdge> ThreadBoneEdgeThroughCdt(SdBoneEdge boneEdge) {
            var start = boneEdge.SourcePoint;
            var currentTriangle = boneEdge.Source.Triangle;
            Debug.Assert(Cdt.PointIsInsideOfTriangle(start, currentTriangle));
            var crossedEdges = new Set<CdtEdge>();
            var end = boneEdge.TargetPoint;
            if (Cdt.PointIsInsideOfTriangle(end, currentTriangle))
                return crossedEdges;

            var threader = new CdtThreader(currentTriangle, start, end);
            while (threader.MoveNext()) {
                CdtEdge piercedEdge = threader.CurrentPiercedEdge;
                Debug.Assert(piercedEdge != null);
                if (Gates.Contains(piercedEdge))
                    crossedEdges.Insert(piercedEdge);
            }

            /*
            CdtEdge piercedEdge = CdtIntersections.FindFirstPiercedEdge(currentTriangle, start, end, out negativeSign, out positiveSign, this.Cdt );
            Debug.Assert(piercedEdge != null);
      
            do {
                if (Gates.Contains(piercedEdge))
                    crossedEdges.Insert(piercedEdge);
            }
            while (CdtIntersections.FindNextPierced(start, end, ref currentTriangle, ref piercedEdge, ref negativeSign, ref positiveSign));
            */
            //if(ddd(boneEdge))
            //CdtSweeper.ShowFront(Cdt.GetTriangles(),null,new []{new LineSegment(boneEdge.SourcePoint,boneEdge.TargetPoint)}, crossedEdges.Select(e=>new LineSegment(e.upperSite.Point,e.lowerSite.Point)));

            return crossedEdges;
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:32,代码来源:SdShortestPath.cs

示例11: CreateAbridgedGraph

        /// <summary>
        /// Create an abstraction of the graph by pairing edges with the shortest
        /// symmetric difference of neighbour sets.  In a perfect world the result
        /// would have half as many nodes as the input graph.  In practice we only
        /// process the edge list once, and don't pair edges whose ends are already
        /// paired so the output may have more than n/2 nodes.
        /// </summary>
        /// <param name="graph">The input graph</param>
        /// <param name="edgeLengthOffset">Initial edge length adjustment percent before proportional adjustments.</param>
        /// <param name="edgeLengthMultiplier">The percent length adjustment unit.</param>
        /// <returns>an abridged graph</returns>
        private GeometryGraph CreateAbridgedGraph(GeometryGraph graph, double edgeLengthOffset, double edgeLengthMultiplier)
        {
            LayoutAlgorithmHelpers.SetEdgeLengthsProportionalToSymmetricDifference(graph, edgeLengthOffset, edgeLengthMultiplier);
            var g2 = new GeometryGraph();
            var nodes = new Set<Node>(graph.Nodes);
            var rand = new Random(1);
            // edges sorted by increasing weight, edges with the same weight shuffled
            var edges = (from e in graph.Edges
                         let r = rand.Next()
                         orderby e.Length, r
                         select e).ToList();
            // mapping from nodes in graph to nodes in g2
            // each node in g2 may represent either 1 or 2 nodes from graph
            var nodeMap = new Dictionary<Node, Node>();

            // populate g2 with nodes representing pairs of nodes, paired across the shortest edges first
            foreach (var e in edges)
            {
                if (nodes.Contains(e.Source) && nodes.Contains(e.Target))
                {
                    var pairNode = new Node
                    {
                        UserData = e
                    };
                    nodeMap[e.Source] = pairNode;
                    nodeMap[e.Target] = pairNode;
                    g2.Nodes.Add(pairNode);
                    nodes.Remove(e.Source);
                    nodes.Remove(e.Target);
                }
            }
            // populate g2 with remaining singleton nodes from graph
            foreach (var u in nodes)
            {
                var v = new Node
                {
                    UserData = u
                };
                g2.Nodes.Add(v);
                nodeMap[u] = v;
            }
            // populate g2 with edges - no duplicates, reverse duplicates or self edges allowed
            var neighbours = new Set<KeyValuePair<Node, Node>>();
            foreach (var e in edges)
            {
                Node u = nodeMap[e.Source], v = nodeMap[e.Target];
                var pair = new KeyValuePair<Node, Node>(u, v);
                var raip = new KeyValuePair<Node, Node>(v, u);
                if (pair.Key != pair.Value
                    && !neighbours.Contains(pair)
                    && !neighbours.Contains(raip))
                {
                    var e2 = new Edge(u, v) { Length = e.Length };
                    neighbours.Insert(pair);
                    g2.Edges.Add(e2);
                }
            }
            return g2;
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:70,代码来源:MultiScaleLayout.cs

示例12: PropagateChangesToClusterParents

 void PropagateChangesToClusterParents() {
     var touchedClusters = new Set<Cluster>();
     foreach (var n in objectsToDrag) {
         var node = n as GeomNode;
         if (node == null) continue;
         foreach (var c in node.AllClusterAncestors)
             if (c != graph.RootCluster && !objectsToDrag.Contains(c))
                 touchedClusters.Insert(c);
     }
     if (touchedClusters.Any())
         foreach (var c in graph.RootCluster.AllClustersDepthFirstExcludingSelf())
             if (touchedClusters.Contains(c))
                 c.CalculateBoundsFromChildren(layoutSettings.ClusterMargin);
 }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:14,代码来源:GeometryGraphEditor.cs

示例13: ReadClusters

        void ReadClusters() {
            XmlRead();
            while (TokenIs(GeometryToken.Cluster))
                ReadCluster();

            FleshOutClusters();
            var rootClusterSet = new Set<Cluster>();
            foreach (var cluster in stringToClusters.Values.Select(c => c.Cluster))
                if (cluster.ClusterParents == null || !cluster.ClusterParents.Any())
                    rootClusterSet.Insert(cluster);

            if (rootClusterSet.Count == 1)
                _graph.RootCluster = rootClusterSet.First();
            else {
                _graph.RootCluster.AddRangeOfCluster(rootClusterSet);
            }

            if (!XmlReader.IsStartElement())
                ReadEndElement();
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:20,代码来源:GeometryGraphReader.cs

示例14: ReadEdgeRailIds

 void ReadEdgeRailIds(LgData lgData, Dictionary<string, Set<string>> edgeIdToEdgeRailsSet) {
     string edgeId = GetAttribute(GeometryToken.EdgeId);
     Set<string> railIdSet;
     edgeIdToEdgeRailsSet[edgeId] = railIdSet = new Set<string>();
     string edgeRailsString = GetAttribute(GeometryToken.EdgeRails);
     LgEdgeInfo edgeInfo = lgData.GeometryEdgesToLgEdgeInfos[idToEdges[edgeId]];
     foreach (var railId in edgeRailsString.Split(' ')) {
         UpdateToRankedEdgeInfoForRail(railId, edgeInfo);
         railIdSet.Insert(railId);
     }
     XmlRead();
 }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:12,代码来源:GeometryGraphReader.cs

示例15: RemoveInsidePortsAndSplitBoundaryIfNeeded

        Set<Point> RemoveInsidePortsAndSplitBoundaryIfNeeded(Polyline boundary) {
            var ret = new Set<Point>();

            if (boundary == null) {
                foreach (var point in portRTree.GetAllLeaves())
                    ret.Insert(point);
                portRTree.Clear();
                return ret;
            }
            Rectangle boundaryBox = boundary.BoundingBox;
            var portLocationsInQuestion = portRTree.GetAllIntersecting(boundaryBox).ToArray();
            foreach (var point in portLocationsInQuestion) {
                switch (Curve.PointRelativeToCurveLocation(point, boundary)) {
                    case PointLocation.Inside:
                        ret.Insert(point);
                        portLocationsToLoosePolylines[point] = boundary;
                        portRTree.Remove(new Rectangle(point), point);
                        break;
                    case PointLocation.Boundary:
                        portRTree.Remove(new Rectangle(point), point);
                        portLocationsToLoosePolylines[point] = boundary;
                        PolylinePoint polylinePoint = FindPointOnPolylineToInsertAfter(boundary, point);
                        if (polylinePoint != null)
                            LineSweeper.InsertPointIntoPolylineAfter(boundary, polylinePoint, point);
                        else
                            throw new InvalidOperationException();
                        break;
                }
            }
            return ret;
        }
开发者ID:danielskowronski,项目名称:network-max-flow-demo,代码行数:31,代码来源:SplineRouter.cs


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