- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在做一项作业,其中我需要对无向图进行 DFS,然后如果找到一个循环则打印一个循环。问题是我可以找到的用于查找循环的任何算法都不会存储循环——它们只是对/错。我当前的代码仅适用于某些图表,但不适用于其他图表。例如,它无法找到 2 节点循环(4-5、5-4)。此外,它现在只适用于定向,而它应该是无向的。
编辑:这不是关于查找和打印循环的其他问题的重复,因为据我所知,其他问题都没有解决如何存储并随后打印循环 - 只是如何查找是否它存在并返回 true/false。
编辑:格式
附上我的遍历代码和我的主要方法
-- 主要方法
public static void main(String args[]) {
//
// Graph g = new Graph(8);
//
// g.add(0, 2);
// g.add(2, 3);
// g.add(3, 1);
// g.add(1, 0);
//
// g.add(4, 5);
// g.add(5, 6);
// g.add(6, 7);
// g.add(7, 4);
//
// Graph g = new Graph(6);
//
// g.add(0, 1);
// g.add(1, 3);
// g.add(2, 3);
// g.add(3, 4);
// g.add(3, 5);
//
// Graph g = new Graph(7);
//
// g.add(0, 1);
// g.add(0, 2);
// g.add(0, 3);
// g.add(3, 4);
// g.add(4, 3);
// g.add(4, 5);
// g.add(4, 6);
Graph g = new Graph(5);
g.add(0, 1);
g.add(2, 3);
g.add(2, 4);
g.add(3, 4);
DepthFirstTraversal dfs = new DepthFirstTraversal(g);
System.out.println("Following is Depth First Traversal");
dfs.DFS();
if (!dfs.isCyclic())
System.out.println("This graph is acyclic");
}
-- 图类
import java.util.LinkedList;
public class Graph {
//Number of Vertices
private int vertices;
//Linked List to hold edges
private LinkedList<Integer> edges[];
public Graph(int verticesGiven) {
this.vertices = verticesGiven;
this.edges = new LinkedList[vertices];
fillNodes(edges, vertices);
}
private static void fillNodes(LinkedList<Integer> edges[], int
vertices) {
for (int counter = 0; counter < vertices; ++counter) {
edges[counter] = new LinkedList();
}
}
void add(int x, int y) {
edges[x].add(y);
}
public int getVertices() {
return vertices;
}
public LinkedList<Integer>[] getEdges() {
return edges;
}
}
-- 遍历和循环搜索
import java.util.*;
public class DepthFirstTraversal {
//Each traversal has a graph
private Graph graph;
//Holds the nodes for each cycle
private List<Integer> cycle = new ArrayList<Integer>();
public DepthFirstTraversal(Graph graph) {
this.graph = graph;
}
private void DFSRecursive(int current, boolean visited[],
LinkedList<Integer> edges[]) {
// Say you visited current node
visited[current] = true;
//Print the current node
System.out.print(current + " ");
// Look at all vertices connected to this one
Iterator<Integer> iterate = edges[current].listIterator();
//Check to see everything this is connected to
while (iterate.hasNext()) {
//Check to see what the next one is
int connected = iterate.next();
//check if you've already visited what it's connected to.
If you haven't, check that one out.
if (!visited[connected])
//Check whatever the current one is connected to
DFSRecursive(connected, visited, edges);
}
}
public void DFS() {
//Check to see how many vertices graph has
int vertices = graph.getVertices();
//Keeps track of which vertices have already been visited
boolean visited[] = new boolean[vertices];
//Visits all of the nodes
for (int counter = 0; counter < vertices; ++counter)
//calls recursive method if this node has not been visited
if (!visited[counter])
DFSRecursive(counter, visited, graph.getEdges());
}
private Boolean isCyclicRecursive(int index, Boolean visited[], int
parent, LinkedList<Integer> edges[]) {
// Mark the current node as visited
visited[index] = true;
//Integer to hold what the node is connected to
Integer connection;
// Recur for all the vertices adjacent to this vertex
Iterator<Integer> iterator = edges[index].iterator();
//Check to see if the current node has a connection
while (iterator.hasNext()) {
//Looks at what is connected to it.
connection = iterator.next();
//If you haven't visited the connection, look at that. Sets the current as the parent of the connection.
if (!visited[connection]) {
cycle.add(index);
if (isCyclicRecursive(connection, visited, index,
graph.getEdges())) {
return true;
} else {
Integer item = new Integer(index);
cycle.remove(item);
}
}
//Checks to see if the thing it's connected to is its parent (you've completed a cycle)
else if (connection != parent) {
//Add parent and connection
cycle.add(index);
cycle.add(connection);
//Only find the things in current cycle
for (int i = 0; i < cycle.size(); i++) {
//Not a true cycle
// if (cycle.size() <= 1)
// return false;
int first = cycle.get(i);
int last = cycle.get(cycle.size() - 1);
if (first == last) {
System.out.print("Cycle Detected: ");
for (int j = 0; j < cycle.size(); j++) {
System.out.print(cycle.get(j).toString() + " ");
}
System.out.println();
return true;
} else {
//only prints things actually in this cycle
cycle.remove(i);
i--;
}
}
return true;
}
}
return false;
}
/**************************************************************/
/* Method: isCyclic
/* Purpose: Checks to see if graph is cyclic
/* Parameters: None
/* Returns: None
/**************************************************************/
public Boolean isCyclic() {
//Mark all vertices as not visited
int vertices = graph.getVertices();
Boolean visited[] = new Boolean[vertices];
for (int counter = 0; counter < vertices; counter++)
visited[counter] = false;
//For every node, check if it is cyclic
for (int counter = 0; counter < vertices; counter++)
//Only check for cyclic if this has been visited
if (!visited[counter])
if (isCyclicRecursive(counter, visited, -1, graph.getEdges()))
return true;
return false;
}
}
最佳答案
我的一个问题是,如果你的图是无向的,你如何将 4-5 和 5-4 视为单独的边?对我来说,在无向图中,4-5 和 5-4 是同一条边,因此不是循环。在有向图上,它们是不同的,因此确实形成了一个循环。另外,图形数组中的所有 LinkedList
对象的长度都是 2 吗?如果您想要无向,可以用 Set
实现替换图中的 LinkedList
对象,但这需要更改一些逻辑。
无论如何,这似乎相关:Best algorithm for detecting cycles in a directed graph
关于java - 查找并打印无向图中的循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46959479/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!