- 1、本文档共46页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第一章:算法概述
1.6 算法复杂性分析 算法分析中常见的复杂性函数 1.6 算法复杂性分析 小规模数据复杂性增长图 1.6 算法复杂性分析 中等规模数据复杂性增长图 小结 程序与算法 渐进表达式 程序复杂性 (1)选择语句: (1.1) if 语句: (1.2) ?语句: if (expression) statement; else statement; exp1?exp2:exp3 y= x9 ? 100:200; 等价于: if (x9) y=100; else y=200; (1.3) switch语句: switch (expression) { case 1: statement sequence; break; case 2: statement sequence; break; ? default: statement sequence; } (2)迭代语句: (2.1) for 循环: for (init;condition;inc) statement; (2.2) while 循环: while (condition) statement; (2.3) do-while 循环: do{ statement; } while (condition); (3)跳转语句: (3.1) return语句: return expression; (3.2) goto语句: goto label; ? label: (4)函数: 例: return-type function name(para-list) { body of the function } int max(int x,int y) { return xy?x:y; } (5)模板template : template class Type Type max(Type x,Type y) { return xy?x:y; } int i=max(1,2); double x=max(1.0,2.0); (6)动态存储分配: (6.1)运算符new : 运算符new用于动态存储分配。 new返回一个指向所分配空间的指针。 例:int ?x;y=new int;?y=10; 也可将上述各语句作适当合并如下: int ?y=new int;?y=10; 或 int ?y=new int(10); 或 int ?y;y=new int(10); (6.2)一维数组 : 为了在运行时创建一个大小可动态变化的一维浮点数组x,可先将x声明为一个float类型的指针。然后用new为数组动态地分配存储空间。 例: float ?x=new float[n]; 创建一个大小为n的一维浮点数组。运算符new分配n个浮点数所需的空间,并返回指向第一个浮点数的指针。 然后可用x[0],x[1],…,x[n-1]来访问每个数组元素。 (6.3)运算符delete : 当动态分配的存储空间已不再需要时应及时释放所占用的空间。用运算符delete来释放由new分配的空间。 例: delete y; delete [ ]x; 分别释放分配给?y的空间和分配给一维数组x的空间。 (6.4)动态二维数组 : 创建类型为Type的动态工作数组,这个数组有rows行和cols列。 template class Type void Make2DArray(Type** x,int rows, int cols) { x=new Type*[rows]; for (int i=0;irows;i++) x[i]=new Type[cols]; } 当不再需要一个动态分配的二维数组时,可按以下步骤释放它所占用的空间。首先释放在for循环中为每一行所分配的空间。然后释放为行指针分配的空间。 释放空间后将x置为0,以防继续访问已被释放的空间。 template class Type void Delete2DArray(Type** x,int rows) { for (int i=0;irows;i++) delete []x[i]; delete []x; x=0; } 算法分析与设计 Algorithm Design Anlysis 关于本课程 课程目的:计算机算法设计与分析导引 以算法设计为主,介绍算法设计的主要
您可能关注的文档
- 第一章 战略管理导论20140302.ppt
- 第一章 摩擦轮传动.ppt
- 第一章 机械运动 第3节 运动的快慢(二).ppt
- 第一章 材料腐蚀与防护.ppt
- 第一章 油气水(石油地质).ppt
- 第一次世界大战的珍贵影像.ppt
- 第一章 流体力学基本知识含计算题.ppt
- 第一章 常用低压电.ppt
- 第一章 海关报关概述.ppt
- 第一章 科技创新的理论基础概述第三节 创新技法(十一)作业.doc
- 人教版九年级英语全一册单元速记•巧练Unit13【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit9【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit11【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit14【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit8【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit4【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit13【单元测试·基础卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit7【速记清单】(原卷版+解析).docx
- 苏教版五年级上册数学分层作业设计 2.2 三角形的面积(附答案).docx
- 人教版九年级英语全一册单元速记•巧练Unit12【单元测试·基础卷】(原卷版+解析).docx
文档评论(0)