算法实验报告3——填色问题——2020.12.21

2023-12-07 13:10

本文主要是介绍算法实验报告3——填色问题——2020.12.21,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载请附:https://blog.csdn.net/weixin_43402353/article/details/111547003

算法实验报告3——填色问题

    • 一丶填色问题
    • 二丶运行结果
    • 三丶试题代码
            • ——梦绕边城月,心飞故国楼——

一丶填色问题

有形如下列图形的地图,图中每一块区域代表一个省份,现请你用红(1)、兰(2)、黄(3)、绿(4)四种颜色给这些省份填上颜色,要求每一省份用一种颜色,且任意两个相邻省份的颜色不能相同,请给出一种符合条件的填色方案。
在这里插入图片描述

二丶运行结果

在这里插入图片描述

三丶试题代码

#项目名称:
#项目简介:
#作   者:key
#开发时间:2020/12/21 21:06'''图的m着色问题'''# 用邻接表表示图
n = 5  # 节点数
count = 0 # 方案数
a, b, c, d, e = range(n)  # 节点名称
graph = [{b, c, d},{a, c, d, e},{a, b, d},{a, b, c, e},{b, d}
]m = 4  # m种颜色
Color = ['红','蓝','黄','绿']x = [0] * n  # 一个解(n元数组,长度固定)注意:解x的下标就是a,b,c,d,e!!!
X = []  # 一组解# 冲突检测
def conflict(k):global n, graph, x# 找出第k个节点前面已经涂色的邻接节点nodes = [node for node in range(k) if node in graph[k]]if x[k] in [x[node] for node in nodes]:  # 已经有相邻节点涂了这种颜色return Truereturn False  # 无冲突# 图的m着色(全部解)
def dfs(k):  # 到达(解x的)第k个节点global n, m, graph, x, X, countif k == n:  # 解的长度超出print(x)count+=1# return# X.append(x[:])else:for color in range(m):  # 遍历节点k的可涂颜色编号(状态空间),全都一样x[k] = Color[color]if not conflict(k):  # 剪枝dfs(k + 1)# 测试
dfs(a)  # 从节点a开始
print('一共有{}种方案'.format(count))
——梦绕边城月,心飞故国楼——

这篇关于算法实验报告3——填色问题——2020.12.21的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466001

相关文章

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操