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


C# IGraph.AddEdge方法代码示例

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


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

示例1: Emit

        private INode Emit(AST a, IGraph to)
        {
            String text = a.getText();
            int iType = a.Type;
            String type = parserpackage.GetTypeName(iType);
            NodeType currentNodeType = GetNodeType(type, to);
            INode currentNode = to.AddNode(currentNodeType);
            currentNode.SetAttribute("value", text);

            if (a.getNumberOfChildren() > 0)
            {
                List<AST> l = GetChildren(a);
                INode previousChild = null;
                foreach (AST current in l)
                {
                    INode childNode = Emit(current, to);
                    EdgeType childType = GetEdgeType("child", to);
                    to.AddEdge(childType, currentNode, childNode);

                    if (previousChild != null)
                    {
                        EdgeType nextType = GetEdgeType("next", to);
                        to.AddEdge(nextType, previousChild, childNode);
                    }
                    previousChild = childNode;
                }
            }
            return currentNode;
        }
开发者ID:jblomer,项目名称:GrGen.NET,代码行数:29,代码来源:ASTdapter.cs

示例2: _initializeSecondCaseGraph

        //
        // Second Case Initialization
        private static void _initializeSecondCaseGraph(ref IGraph<string> graph)
        {
            // Clear the graph
            graph.Clear();

            //
            // Add vertices
            var verticesSet = new string[] { "a", "b", "c", "d", "e", "f", "s", "v", "x", "y", "z" };
            graph.AddVertices (verticesSet);

            //
            // Add edges

            // Connected Component #1
            // the vertex "e" won't be connected to any other vertex

            // Connected Component #2
            graph.AddEdge("a", "s");
            graph.AddEdge("a", "d");
            graph.AddEdge("s", "x");
            graph.AddEdge("s", "a");
            graph.AddEdge("x", "d");

            // Connected Component #3
            graph.AddEdge("b", "c");
            graph.AddEdge("b", "v");
            graph.AddEdge("c", "f");
            graph.AddEdge("c", "v");
            graph.AddEdge("f", "b");

            // Connected Component #4
            graph.AddEdge("y", "z");
        }
开发者ID:ChijunShen,项目名称:C-Sharp-Algorithms,代码行数:35,代码来源:GraphsBipartiteColoringTest.cs

示例3: Read

        public bool Read(IGraph myGraph, FileStream myInputStream)
        {
            // use a streamreader .. better handling
            StreamReader reader = null;
            // stores the added vertices for fast retrieval
            var addedVertices = new Dictionary<string, IVertex>();

            try
            {
                reader = new StreamReader(myInputStream);
                String line;    // current line in file
                String[] edge;  // contains source and target vertex id
                IVertex source; // source vertex
                IVertex target; // target vertex
                var count = 0L; // number of processed edges

                while ((line = reader.ReadLine()) != null)
                {
                    if (!line.StartsWith(EdgeListTokens.LINE_COMMENT)) // just a comment
                    {
                        // line look like that "0   1", splitting it to get source and target id
                        edge = line.Split(EdgeListTokens.SOURCE_TARGET_SEPARATOR);

                        // got two id's?
                        if (edge.Length == 2)
                        {
                            // check if source has been added before
                            if (!addedVertices.TryGetValue(edge[0], out source))
                            {
                                // if not, create new vertex
                                source = myGraph.AddVertex(edge[0]);
                                addedVertices.Add(edge[0], source);
                            }
                            // check if target has been added before
                            if (!addedVertices.TryGetValue(edge[1], out target))
                            {
                                // if not, create new vertex
                                target = myGraph.AddVertex(edge[1]);
                                addedVertices.Add(edge[1], target);
                            }

                            if (myGraph.AddEdge(source, target) != null)
                            {
                                count++;
                            }
                        }
                    }
                }
            }
            catch (IOException ex)
            {
                // TODO add logging here
                return false;
            }
            finally
            {

                reader.Close();
            }

            return true;
        }
开发者ID:s1ck,项目名称:OwlerDB,代码行数:62,代码来源:EdgeListReader.cs

示例4: _initializeFirstCaseGraph

        //
        // Second Case Initialization
        private static void _initializeFirstCaseGraph(ref IGraph<string> graph)
        {
            // Clear the graph
            graph.Clear();

            //
            // Add vertices
            var verticesSet = new string[] { "a", "b", "c" };
            graph.AddVertices (verticesSet);

            // 
            // Add Edges
            graph.AddEdge("a", "b");
            graph.AddEdge("b", "c");
            graph.AddEdge("c", "a");

        }
开发者ID:ChijunShen,项目名称:C-Sharp-Algorithms,代码行数:19,代码来源:GraphsBipartiteColoringTest.cs


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