人工智能课程设计报告报告_罗马尼亚度假问题

上传人:l**** 文档编号:266494304 上传时间:2022-03-15 格式:DOC 页数:30 大小:127KB
返回 下载 相关 举报
人工智能课程设计报告报告_罗马尼亚度假问题_第1页
第1页 / 共30页
人工智能课程设计报告报告_罗马尼亚度假问题_第2页
第2页 / 共30页
人工智能课程设计报告报告_罗马尼亚度假问题_第3页
第3页 / 共30页
人工智能课程设计报告报告_罗马尼亚度假问题_第4页
第4页 / 共30页
人工智能课程设计报告报告_罗马尼亚度假问题_第5页
第5页 / 共30页
点击查看更多>>
资源描述

《人工智能课程设计报告报告_罗马尼亚度假问题》由会员分享,可在线阅读,更多相关《人工智能课程设计报告报告_罗马尼亚度假问题(30页珍藏版)》请在金锄头文库上搜索。

1、.课 程:人工智能课程设计报告 班 级:姓 名:学 号:指导教师:赵曼2015年11月- 29 - / 30.人工智能课程设计报告课程背景人工智能Artificial Intelligence,英文缩写为AI。它是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。 人工智能是计算机科学的一个分支,它企图了解智能的实质,并生产出一种新的能以人类智能相似的方式做出反应的智能机器,该领域的研究包括机器人、语言识别、图像识别、自然语言处理和专家系统等。人工智能从诞生以来,理论和技术日益成熟,应用领域也不断扩大,可以设想,未来人工智能带来的科技产品,将会是人类智慧的容

2、器。人工智能是对人的意识、思维的信息过程的模拟。人工智能不是人的智能,但能像人那样思考、也可能超过人的智能。人工智能是一门极富挑战性的科学,从事这项工作的人必须懂得计算机知识,心理学和哲学。人工智能是包括十分广泛的科学,它由不同的领域组成,如机器学习,计算机视觉等等,总的说来,人工智能研究的一个主要目标是使机器能够胜任一些通常需要人类智能才能完成的复杂工作。但不同的时代、不同的人对这种复杂工作的理解是不同的。人工智能是计算机学科的一个分支,二十世纪七十年代以来被称为世界三大尖端技术之一空间技术、能源技术、人工智能。也被认为是二十一世纪三大尖端技术基因工程、纳米科学、人工智能之一。这是因为近三十

3、年来它获得了迅速的发展,在很多学科领域都获得了广泛应用,并取得了丰硕的成果,人工智能已逐步成为一个独立的分支,无论在理论和实践上都已自成一个系统。人工智能是研究使计算机来模拟人的某些思维过程和智能行为如学习、推理、思考、规划等的学科,主要包括计算机实现智能的原理、制造类似于人脑智能的计算机,使计算机能实现更高层次的应用。人工智能将涉及到计算机科学、心理学、哲学和语言学等学科。可以说几乎是自然科学和社会科学的所有学科,其范围已远远超出了计算机科学的范畴,人工智能与思维科学的关系是实践和理论的关系,人工智能是处于思维科学的技术应用层次,是它的一个应用分支。从思维观点看,人工智能不仅限于逻辑思维,要

4、考虑形象思维、灵感思维才能促进人工智能的突破性的发展,数学常被认为是多种学科的基础科学,数学也进入语言、思维领域,人工智能学科也必须借用数学工具,数学不仅在标准逻辑、模糊数学等范围发挥作用,数学进入人工智能学科,它们将互相促进而更快地发展。题目一:罗马利亚度假问题一.问题描述分别用代价一致的宽度优先、有限制的深度优先预设搜索层次、贪婪算法和A*算法求解罗马利亚度假问题。即找到从初始地点 Arad到 目的地点 Bucharest 的一条路径。要求:分别用文件存储地图和启发函数表,用生成节点数比较几种算法在问题求解时的效率,并列表给出结果。数据如下:1、地图2、启发函数值Arad 366Mehad

5、ia 241Bucharest 0Neamt 234Craiova 160Oradea 380Doberta 242Pitesti 100Eforie 161Rimmicu_Vikea 193Fagaras 176Sibiu 253Glurgiu 77Timisoara 329Hirsova 151Urziceni 80Iasi 226Vaslui 199Lugoj 244Zerind 3743、地图数据表0 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 140 1000 118 1000 1000 1000 1000 1000 75100

6、0 0 1000 1000 1000 1000 75 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 70 10001000 1000 0 1000 1000 1000 1000 101 1000 1000 211 1000 90 1000 1000 85 1000 1000 1000 10001000 1000 1000 0 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 87 1000 1000 10001000 1000 1000 1000 0 1000

7、120 138 1000 146 1000 1000 1000 1000 1000 1000 1000 1000 1000 10001000 1000 1000 1000 1000 0 1000 1000 1000 1000 1000 151 1000 1000 1000 1000 1000 1000 1000 711000 75 1000 1000 120 1000 0 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 10001000 1000 101 1000 138 1000 1000 0 1000 97 1000

8、1000 1000 1000 1000 1000 1000 1000 1000 10001000 1000 1000 1000 1000 1000 1000 1000 0 1000 1000 1000 1000 1000 86 1000 1000 1000 1000 10001000 1000 1000 1000 146 1000 1000 97 1000 0 1000 80 1000 1000 1000 1000 1000 1000 1000 10001000 1000 211 1000 1000 1000 1000 1000 1000 1000 0 99 1000 1000 1000 10

9、00 1000 1000 1000 1000140 1000 1000 1000 1000 151 1000 1000 1000 80 99 01000 1000 1000 1000 1000 1000 1000 10001000 1000 90 1000 1000 1000 1000 1000 1000 1000 1000 1000 0 1000 1000 1000 1000 1000 1000 1000118 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 0 1000 1000 1000 1000 111 10001

10、000 1000 1000 1000 1000 1000 1000 1000 86 1000 1000 1000 1000 1000 0 98 1000 1000 1000 10001000 1000 85 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 98 0 1000 1000 1000 10001000 1000 1000 87 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 0 92 1000 10001000 1000 1000 1000 1000

11、1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 92 0 1000 10001000 70 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 111 1000 1000 1000 1000 0 100075 1000 1000 1000 1000 71 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 1000 0二.设计分析1.算法分析 1宽度优先搜索算法广度优先搜索使用队列queue来实现1、把根节点

12、放到队列的末尾。2、每次从队列的头部取出一个元素,查看这个元素所有的下一级元素,把它们放到队列的末尾。并把这个元素记为它下一级元素的前驱。3、找到所要找的元素时结束程序。4、如果遍历整个图还没有找到,结束程序。2深度优先搜索算法深度优先搜索用栈stack来实现,整个过程可以想象成一个倒立的树形:1、把根节点压入栈中。2、每次从栈中弹出一个元素,搜索所有在它下一级的元素,把这些元素压入栈中。并把这个元素记为它下一级元素的前驱。3、找到所要找的元素时结束程序。4、如果遍历整个树还没有找到,结束程序。3贪婪算法1.建立数学模型来描述问题把求解的问题分成若干个子问题。对每一子问题求解,得到子问题的局部

13、最优解。把子问题的解局部最优解合成原来解问题的一个解。实现该算法的过程:从问题的某一初始解出发;while 能朝给定总目标前进一步do求出可行解的一个解元素;由所有解元素组合成问题的一个可行解。4A*算法A*1 A-Star算法是一种静态路网中求解最短路最有效的直接搜索方法。公式表示为: f=g+h,其中 f 是从初始点经由节点n到目标点的估价函数,g 是在状态空间中从初始节点到n节点的实际代价,h 是从n到目标节点最佳路径的估计代价。保证找到最短路径最优解的条件,关键在于估价函数f的选取:估价值h= n到目标节点的距离实际值,这种情况下,搜索的点数多,搜索范围大,效率低。但能得到最优解。并且

14、如果h=d,即距离估计h等于最短距离,那么搜索将严格沿着最短路径进行, 此时的搜索效率是最高的。如果 估价值实际值,搜索的点数少,搜索范围小,效率高,但不能保证得到最优解。2.数据结构1图结构:实现存储罗马尼亚度假问题的图空间;抽象图结构的实现:typedefstruct/图节点类型char cityname20;int value;int cost;Ver;classGraph /图结构public:Graph;Graph;Ver VMaxV;int edgeMaxVMaxV;int numofedges; /注意这个变量的引用位置/读取地图节点信息void ReadVertex;/读取地图

15、边关系信息void ReadEdge;/取与第V个节点的第一个邻接点int GetFirstVertex;/找到第V1个节点的V2之后的下一个邻接节点int GetNextVertex;int GetVerValue;/获取Vindex 的ver 的value值int GetVerCost;/获取Vindex 的ver 的cost 值int GetEdge;/获取edgerowcol 的值void SetVerCost;2队列结构宽度优先算法以及A*算法使用到。抽象队列结构实现:classSeqQueuepublic:SeqQueue;SeqQueue;void QueueInitiate;int QueueNotEmpty;int Queu

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号