首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python中随机图的着色

python中随机图的着色
EN

Stack Overflow用户
提问于 2022-01-19 15:55:30
回答 1查看 70关注 0票数 0

我有一个脚本,它在python中实现贪婪的着色,换句话说,它用四种颜色对图进行着色。我想要生成一个随机图,然后将它传递到上面链接上的脚本中,以对其着色。这就是我如何生成一个随机图(以字典的形式):

代码语言:javascript
复制
list = [1,2,3,4,5]
d = {i: sample([j for j in q if i != j], randrange(1, len(q) - 1))
for i in q}

所以,我现在需要的是某种函数,它将创建的字典传递给贪婪的着色脚本,因为如果我在脚本中的函数中输入图d,就会得到以下错误:

代码语言:javascript
复制
    Traceback (most recent call last):
  File "/private/var/mobile/Containers/Shared/AppGroup/9244016A-6D10-4627-B39B-6D63D3F9D22C/Pythonista3/Documents/nuovaprova.py", line 88, in <module>
    greedyColoring(d, 5)
  File "/private/var/mobile/Containers/Shared/AppGroup/9244016A-6D10-4627-B39B-6D63D3F9D22C/Pythonista3/Documents/nuovaprova.py", line 33, in greedyColoring
    if (result[i] != -1):
IndexError: list index out of range
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-01-19 16:30:31

从0启动list q,如下所示:

代码语言:javascript
复制
q = [0, 1, 2, 3, 4]
d = {i: sample([j for j in q if i != j], randrange(1, len(q) - 1))
     for i in q}

然后,可以将字典d直接传递到脚本中,如下所示:

代码语言:javascript
复制
 greedyColoring(d, 5)

给定的脚本将图表示为list of lists,其中list的索引表示节点,相应的值表示它的相邻节点,因此还可以将d转换为[node for node in d.values()]列表,然后传入函数如下:

代码语言:javascript
复制
greedyColoring([node for node in d.values()], 5) 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70773718

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档