地图着色问题实验报告

地图着色问题实验报告

ID:28240206

大小:95.00 KB

页数:8页

时间:2018-12-08

地图着色问题实验报告_第1页
地图着色问题实验报告_第2页
地图着色问题实验报告_第3页
地图着色问题实验报告_第4页
地图着色问题实验报告_第5页
资源描述:

《地图着色问题实验报告》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、-算法设计与分析课程设计题目:地图着色问题文档:物联网工程学院物联网工程专业学号学生姓名班级二〇一三年十二月.---一、问题描述:地图着色问题设计要求:已知中国地图,对各省进行着色,要求相邻省所使用的颜色不同,并保证使用的颜色总数最少.二、概要设计(流程图)步骤:1.已知中国地图,对各省进行着色,要求相邻省所使用的颜色不同,并保证使用的颜色总数最少;2.将各省进行编号,然后利用无向图的顶点之间的边来表示各省的相邻关系;3.将各编号进行逐一着色,利用循环语句遍历各省,判断语句判断是否符合要求;4.演示程序,以用户和计算机的对话方式进行;5.最后对结果做出

2、简单分析及总结。流程图.---三、源程序#include#include#defineMAXedg100#defineMAX0#defineN4/*着色的颜色数*/intcolor[30]={0};/*来存储对应块的对应颜色*/typedefcharvextype;typedefintadjtype;typedefstruct/*定义图*/{vextypevexs[MAXedg];/*存放边的矩阵*/adjtypearcs[MAXedg][MAXedg];/*图的邻接矩阵*/intvnum,arcnum;/*图的顶

3、点数和边数*/}Graph;intLocateVex(GraphG,charu){inti;for(i=1;i<=G.vnum;i++){if(u==G.vexs[i])returni;}if(i==G.vnum){printf("Erroru!");exit(1);}.---return0;}voidCreateGraph(Graph&G)/*输入图*/{inti,j,k,w;vextypev1,v2;printf("输入图的顶点数和边数:");scanf("%d%d",&G.vnum,&G.arcnum);getchar();printf(

4、"输入图的各顶点:");for(i=1;i<=G.vnum;i++){scanf("%c",&G.vexs[i]);getchar();}for(i=0;i<=G.vnum;i++)for(j=0;j<=G.vnum;j++)G.arcs[i][j]=MAX;printf("输入边的两个顶点和权值(均用1表示):");for(k=0;k

5、v1);j=LocateVex(G,v2);G.arcs[i][j]=w;G.arcs[j][i]=w;}.---}voidPrintGraph(GraphG)/*输出图的信息*/{inti,j;printf("图的各顶点:");for(i=1;i<=G.vnum;i++)printf("%c",G.vexs[i]);printf("");printf("图的邻接矩阵:");for(i=1;i<=G.vnum;i++){for(j=1;j<=G.vnum;j++)printf("%d",G.arcs[i][j]);printf("");

6、}}intcolorsame(ints,GraphG)/*判断这个颜色能不能满足要求*/{inti,flag=0;for(i=1;i<=s-1;i++)/*分别与前面已经着色的几块比较*/if(G.arcs[i][s]==1&&color[i]==color[s]){flag=1;break;}returnflag;}voidoutput(GraphG)/*输出函数*/.---{inti;for(i=1;i<=G.vnum;i++)printf("%d",color[i]);printf("");}voidtrycolor(ints,GraphG)

7、/*s为开始图色的顶点,本算法从1开始*/{inti;if(s>G.vnum)/*递归出口*/{output(G);exit(1);}else{for(i=1;i<=N;i++)/*对每一种色彩逐个测试*/{color[s]=i;if(colorsame(s,G)==0)trycolor(s+1,G);/*进行下一块的着色*/}}}intmain(){GraphG;CreateGraph(G);.---PrintGraph(G);printf("着色方案:");trycolor(1,G);return0;}四、运行主要结果界面贴图1、中国地图简略图

8、2、取地图一部分进行测试有6个顶点,8条边。各点相邻情况为:a-b,a-e,b-c,b-d,b

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。