第1讲算法引论课件.ppt
《第1讲算法引论课件.ppt》由会员分享,可在线阅读,更多相关《第1讲算法引论课件.ppt(25页珍藏版)》请在三一办公上搜索。
1、例子:给定两个正整数a和b,求它们的最大公因子算法:欧几里德算法输入:正整数a、b输出:a和b的最大公因子,第一章 算法引论,1.1 算法的基本概念,一、什么是算法及其与程序的区别,求解的数学模型为:gcd(a,b)=gcd(b,a)/gcd为求(a,b)的最大公因子的函数,其中abgcd(a,b)=gcd(b,a%b)/%为取模运算,求a除b的余数=gcd(b,0)/当a%b=0时,b为(a,b)的最大公因子,什么是算法?,它是一组有穷规则的集合,它规定了解决某一 特定类型问题的一系列运算。,Gcd(int a,int b)/a,bN+1 if a b2 then swap(a,b);/交换
2、a和b,保证a比b大3 n a%b;/a和b取余4 while n05 do a b;6 b n;7 n a%b;8 return b;,二、算法的特征 1、确定性 2、能行性 3、输入 4、输出 5、有穷性:一个算法总是在有限步之后结束,且每一步都可在有穷时间内完成.,算法与程序的区别:程序:与某种语言有关,能直接在机器上运行。算法:与特定的语言无关,可用任何语言实现,甚至可以用自然语言实现,但是一般为了避免二义性,本书采用类C语言描述。,一个算法总是在执行了有穷步骤的运算后终止,否则就是一个计算过程。,有穷性与有效性的关系:,三、评价算法的标准,有穷性是对算法的基本要求,如果一个算法要能使
3、用,必须具有有效性。有效性是指算法在有效的时间里终止。,时间复杂性和空间复杂性,四、本书介绍的内容,1、如何设计算法:2、如何表示算法:类C语言(自学page 2-5)3、如何确定(或称证明)算法:4、如何分析算法:5、如何测试算法:作时空分布图,1.2 算法设计的步骤,一、问题的描述,例:货郎担问题 设售货员在一天内要到5个城市去推销货物,已知从一个城市到其他城市的费用,求总费用最少的路线。给出的信息主要有五个城市的关系图及相应的费用矩阵。,二、模型的拟制 建模阶段至少要考虑以下两个基本问题:1)最适合于这个问题的数学结构是什么?2)有没有已经解决了的类似问题可供借鉴?,在模型建立好了以后,
4、应该依据所选定的模型对问题重新陈述,并考虑下列问题:,(1)模型是否清楚地表达了与问题有关的所有重要的信息?(2)模型中是否存在与要求的结果相关的数学量?(3)模型是否正确反映了输入、输出的关系?(4)对这个模型处理起来困难吗?,对于货郎担问题,其数学模型是带权图,与此图相关的是费用矩阵。,以货郎担问题为例:采用枚举法。分析:,三、算法的详细设计,算法的详细设计是指设计求解某个具体问题的一系列步骤,并且这些步骤可以通过计算机的各种操作来实现。,输入:城市数目n;费用矩阵C=(cij)n*n输出:旅行路线TOUR;最小费用MIN,Salesman(n)i 1;tour0;min while i=
5、(n-1)!do pPHRMUTI(n-1,i);/PHRMUTI(n-1,i)是生成1到n-1的第i个排列的子过程 cost(T(p)EFP(c,T(p);/EFP(c,T)是由费用矩阵c及路线T(p)所算得的总费用 if cost(T(p)min tourT(p);mincost(T(p)ii+1;print min,tour,四、算法的正确性 可以分两步考虑:(1)算法的终止性;(2)算法的每一步是否都正确 算法的正确性并不蕴涵算法的有效性。,五、算法分析 时间复杂性和空间复杂性 以上货郎担问题的时间复杂性是:O(n!),六、文档的编制,(1)注释(2)算法的流程图(3)对输入/输出的要
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 算法 引论 课件
链接地址:https://www.31ppt.com/p-3755350.html