为什么我只认为Leetcode的时间复杂性“ 133”。克隆图是o(e)而不是o(v+ e)
我有一个关于leetcode图问题的问题[133。克隆图]“ https://leetcode.com/problems/clone-graph/”。
我使用DFS解决了这个问题,这是我的代码JavaScript:
/**
* // Definition for a Node.
* function Node(val, neighbors) {
* this.val = val === undefined ? 0 : val;
* this.neighbors = neighbors === undefined ? [] : neighbors;
* };
*/
/**
* @param {Node} node
* @return {Node}
*/
var cloneGraph = function(node) {
if(!node) return null;
const visited = new Map();
const dfs = (node) => {
const n = [];
if(visited.has(node.val)) return visited.get(node.val);
let newNode = new Node(node.val);
visited.set(node.val,newNode);
for(let on of node.neighbors){
n.push(dfs(on));
}
newNode.neighbors = n;
return newNode;
}
return dfs(node);
};
我的解决方案图就是这样:
< img src =“ https://i.sstatic.net/tgjrh.png” alt =“在此处输入图像说明”>
假定v/e是图形的顶点/边缘。
我发现很多人说这个问题的时间复杂性是o(v+e),但我无法抓住它,因为在这种情况下,我认为这是o(e)。
我认为,我们的输入只是一个节点对象而不是相邻列表,它是一个无方向的图,因此我们不需要检查每个节点的连续序列,我们只需要从输入“节点”和然后它将扫描整个图,这只是树木问题的一种普通DF。
那里有什么错吗?如果是这样,有人可以解释一下为什么我对此解决方案有误会吗?
I have a question about the leetcode graph problem [133. Clone Graph] "https://leetcode.com/problems/clone-graph/".
I used DFS to solve this problem and here is my code by javascript:
/**
* // Definition for a Node.
* function Node(val, neighbors) {
* this.val = val === undefined ? 0 : val;
* this.neighbors = neighbors === undefined ? [] : neighbors;
* };
*/
/**
* @param {Node} node
* @return {Node}
*/
var cloneGraph = function(node) {
if(!node) return null;
const visited = new Map();
const dfs = (node) => {
const n = [];
if(visited.has(node.val)) return visited.get(node.val);
let newNode = new Node(node.val);
visited.set(node.val,newNode);
for(let on of node.neighbors){
n.push(dfs(on));
}
newNode.neighbors = n;
return newNode;
}
return dfs(node);
};
My solution graph would be like this:
Assumed that V/E is the Vertexes/Edges of the Graph.
I figured out that there're lots of people said the time complexity of this problem is O(V+E), but I can't catch it because I think it's O(E) in this case.
In my opinion, our input is only a node object instead of an adjacent list and it's an undirected graph, so we don't need to check a consecutive sequence for each node, we just need to trace it from the input "node" and then it would scan the whole graph, that's only a kind of normal DFS like trees problem.
Is it anything wrong there? If it is, Could anyone please explain why I got a misunderstanding of this solution?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
你是绝对正确的。代码挑战表明该图是连接的,这是一个重要的信息。这意味着至少有v -1边。由于该算法仅通过访问边缘仅在每个方向上访问一次,而不会以另一种方式访问节点,而不是通过边缘行驶(一次是第一个节点),o(e)与o(v+)相同e)。
You are absolutely right. The code challenge says that the graph is connected and this is an important information. That means that there are at least V - 1 edges. Since the algorithm is driven by visiting edges only once in each direction, and nodes are not visited in another way than by traveling over an edge (except once, for the first node), O(E) is the same as O(V+E).
在每个带有
n
顶点的简单图表中,边数均由n^2
绑定,因此o(e)= o(v^2)。完整的图表可以看到,这种界限是紧密的(每个顶点彼此连接)。
但是,对于许多(自然或人为的)图类别的类别类别,对事先已知的边缘数量有限制(例如,树具有
v-1
edges),因此,根据不同的不同而言,表达复杂性测量值很普遍在v
和e
上被正式视为独立实体。通常,dfs涉及
o(v+e)
操作,因为...(接近)访问了每个边缘:只有事先知道它已经在已经看到的顶点结束的情况下,您才可以跳过一个,但是要知道您需要遵循边缘 :一旦您看到所有顶点,请立即停止DF。但这取决于DFS的目的 - 如果要构建一个生成树,则可以,如果要检测一个周期,则不是。
返回到您的特定设置:在琐碎的情况下,所有顶点和所有边都必须访问以克隆图,因此
o(v+e)
。但是,如果该图已连接,您会事先知道访问所有边缘后您已经看到了所有顶点,因此:o(e)
。In every simple graph with
n
vertices, the number of edges is bound byn^2
, soO(E) = O(V^2)
. This bound is tight as can be seen with the complete graphs (every vertex connects to each other).However, for many (natural or contrived) classes of graphs there are restrictions on the number of edges known beforehand (eg. trees have exactly
V-1
edges), therefore it is popular to express complexity measures depending onV
andE
being formally treated as independent entities.In general, DFS involves
O(V+E)
operations since ...There seems to be a possible shortcut: stop the dfs as soon as you've seen all vertices. But that depends on the purpose of the dfs - if you want to build a spanning tree, it is ok, if you want to detect a cycle it is not.
Back to your specific setting: Trivially all vertices and all edges must be visited to clone a graph, thus
O(V+E)
. However, if the graph is connected, you know beforehand that you'll have seen all vertices after having visited all edges, thus:O(E)
.