C语言程序试题

news/2024/7/3 0:47:54

  一个无向连通图G点上的哈密尔顿(Hamiltion)回路是指从图G上的某个顶点出发,经过图上所有其他顶点一次且仅一次,最后回到该顶点的路劲。一种求解无向图上哈密尔顿回路算法的基础实现如下:

  假设图G存在一个从顶点V0出发的哈密尔顿回路V1——V2——V3——...——Vn-1——V0。算法从顶点V0出发,访问该顶点的一个未被访问的邻接顶点V1,接着从顶点V1出发,访问V1一个未被访问的邻接顶点V2,..。;对顶点Vi,重复进行以下操作:访问Vi的一个未被访问的邻接接点Vi+1;若Vi的所有邻接顶点均已被访问,则返回到顶点Vi-1,考虑Vi-1的下一个未被访问的邻接顶点,仍记为Vi;知道找到一条哈密尔顿回路或者找不到哈密尔顿回路,算法结束。

C代码】

下面是算法的C语言实现。

1)常量和变量说明

  n :图G中的顶点数

  c[][]:图G的邻接矩阵

  k:统计变量,当期已经访问的定点数为k+1

  x[k]:第k个访问的顶点编号,从0开始

  visited[x[k]]:第k个顶点的访问标志,0表示未访问,1表示已访问

2)C程序

 1 #include <stido.h>
 2 #include <stidb.h>
 3 #define MAX 100
 4 
 5 void Hamilton(int n,int x[MAX,int c[MAX][MAX]){
 6   in t ;
 7   in t visited[MAX];
 8   int k;
 9   /*初始化x数组和visited数组*/
10   for(i=0:i<n;i++)11     x[i]=0;
12     visited[i]=0;
13   14   /*访问起始顶点*/
15   k=0;
16   (visited[0]=1);
17   x[0]=0;
18   k=k+1;
19   /*访问其他顶点*/
20   while(k>=0){
21     x[k]=x[k]+1;
22     while(x[k]><n){
23       if(visited[x[k]]==0) &&c[x-[k-1]][x[k]=1){/*邻接顶点x[k]未被访问过*/
24         break25       }else26         x[k] = x[k] + 1;
27       28     29     if(x[k]<n-1&&visited[x[k]]==1){ /*找到一条哈密尔顿回路*/
30       for(k=0;k<n;k++)31         prinf(〝%d--〝,x[k] ; /*输出哈密尔顿回路*/
32       33       prinf(〝%d--〝,x[0] ;
34       return35     }else if x[k]<n&&k<n-1){/*设置当期顶点的访问标志,继续下一个顶点*/
36       visited[x[k]]=1;
37       k=k+1; 38     }else/*没有未被访问过的邻接顶点,回退到上一个顶点*/ 39       x[k]=040       visited x[k]=041       k=k-142     43   44

【问题1】(10分)

  根据题干说明。填充C代码中的空(1)~(5).

  答案:代码中标注红色的即为答案!

【问题2】(5分)

  根据题干说明和C代码,算法采用的设计策略为(6),该方法在遍历图的顶点时,采用的是(7)方法(深度优先或广度优先)。

  答案:

    6:回溯法

    7:深度优先

转载于:https://www.cnblogs.com/yszd/p/9496685.html


http://lihuaxi.xjx100.cn/news/236403.html

相关文章

Guava Cache本地缓存在 Spring Boot应用中的实践

概述 在如今高并发的互联网应用中&#xff0c;缓存的地位举足轻重&#xff0c;对提升程序性能帮助不小。而 3.x开始的 Spring也引入了对 Cache的支持&#xff0c;那对于如今发展得如火如荼的 Spring Boot来说自然也是支持缓存特性的。当然 Spring Boot默认使用的是 SimpleCache…

php include include_once 区别,「PHP」include()、include_once()、require()、require_once()的用法及区别...

1、include&#xff1a;使用include引用外部文件时&#xff0c;只有代码执行到include代码段时&#xff0c;调用的外部文件才会被引用并读取&#xff0c;当引用的文件发生错误时&#xff0c;系统只会给出个警告错误&#xff0c;而整个php文件会继续执行。使用require语句来调用…

面试题收集最新

Java高级程序员面试题------https://www.cnblogs.com/mengdou/p/7233398.html Java高级工程师面试题总结及参考答案-----https://www.cnblogs.com/java1024/p/8594784.html Java高级程序员&#xff08;5年左右&#xff09;面试的题目集----https://blog.csdn.net/fangqun663775…

Clojure程序设计

《Clojure程序设计》基本信息作者&#xff1a; (美)Stuart Halloway Aaron Bedra [作译者介绍]出版社&#xff1a;人民邮电出版社ISBN&#xff1a;9787115308474上架时间&#xff1a;2013-3-1出版日期&#xff1a;2013 年3月开本&#xff1a;16开页码&#xff1a;230版次&#…

ubuntu系统php环境变量设置,Ubuntu系统环境变量详解

使用Ubuntu 进行开发绕不开的就是环境变量的配置&#xff0c;由于Linux系统严格的权限管理&#xff0c;造成Ubuntu系统有多个环境变量配置文件&#xff0c;如果不了解其调用顺序&#xff0c;很有可能遇到配置了环境变量&#xff0c;而没有其作用的问题。本文将介绍Ubuntu Linux…

Linux下如何查看版本信息

2019独角兽企业重金招聘Python工程师标准>>> Linux下如何查看版本信息&#xff0c; 包括位数、版本信息以及CPU内核信息、CPU具体型号等等&#xff0c;整个CPU信息一目了然。  1、# uname &#xff0d;a &#xff08;Linux查看版本当前操作系统内核信息&#xff09…

迭代法移动盘子java,算法学习--日记(牛顿迭代法)

牛顿迭代法概念理解牛顿迭代法可以使用函数极限角度无限迭代趋近于某一点理解。迭代算法解决问题&#xff0c;需要做好3个方面的工作&#xff1a;确定迭代变量 在可以用迭代算法解决的问题中&#xff0c;至少存在一个可直接或间接地不断由旧值递推出新值的变量&#xff0c;这个…

医院六级电子病历建设思路及要点

产生背景 在医院电子病历信息化发展的过程中&#xff0c;先后经历了纸质病历、电子病历、结构化电子病历以及具有全医疗过程管理能力的电子病历四个阶段。临床业务需求质量的逐步提升&#xff0c;标准规范的逐步细化&#xff0c;互联网战略的落地实施&#xff0c;无疑对目前电子…