我被要求设计一个“递减征服”算法来检查给定的图是否是二部图, 我发现了一个算法,但我不知道它是否被认为是一个递减征服。 如果是什么是运行时间复杂度,我如何分析下面代码的最坏情况的时间复杂度。
def isBipartite(G , V):
color = [-1]*V
return colorgraph(G,color,0,1,V)
def colorgraph(G,color,pos,c,V):
if color[pos] != -1 and color[pos] != c:
return False
color[pos] = c
res = True
for i in range (0,V):
if G[pos][i]:
if color[i] == -1:
res &= colorgraph(G,color,i,1-c,V)
if color[i] != -1 and color[i] != 1-c:
return False
if not res :
return False
return True
驱动代码
graph = [[0,1,1,1],
[1,0,1,0],
[0,1,0,1],
[1,0,1,0]]
V = len(graph)
if isBipartite(graph,V):
print("yes , the graph is Bipartite !!!")
else:
print("no , the graph is not Bipartite !!!")
有人知道吗? 问题来源StackOverflow 地址:/questions/59382189/is-the-given-graph-bipartite-or-not
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。