欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数据结构与算法设计PPT (2).pdf

    • 资源ID:52869507       资源大小:16.84MB        全文页数:30页
    • 资源格式: PDF        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数据结构与算法设计PPT (2).pdf

    第1章 绪论1.3 抽象数据类型及其表示定义:一组性质相同的值的集合,以及定义于这个值集合上的一组操作的总称.-数据类型中值的特征-数据在存储器中的编码形式-存储空间的大小和值的范围-对数据可以进行的运算种类基本数据类型int x=100,y=200;int z1=x+y;int z2=x*y;int z3=x%y;C语言中的数据类型char int float double void字符型 整型 浮点型 双精度型 无值int x x可以进行多少种运算?基本数据类型 高级语言的数据类型使我们编写代码时不必考虑每一种数据在计算机内部的表示细节和运算的实现细节 可以直接按照数据类型的外部抽象数据特征来使用数据,方便了程序设计 信息封装是计算机硬件系统和软件系统中使用的基本原则,信息封装可以简化用户对概念的理解。用户在使用数据类型时,可以不必了解内部的实现细节。基本数据类型 复合数据类型是由基本数据类型组合而成的数据类型.复合数据类型本身又可以参与定义结构更为复杂的数据元素类型 数据元素的类型不限于基本数据类型,也可以根据应用需要灵活进行定义数据元素的类型:复合数据类型class studentstring number;string name;date birthday;int class;int grade;string colleage;string major;public:student();void set();void modify();void display()const;student();数据元素的类型:复合数据类型class studentstring number;string name;date birthday;int class;int grade;string colleage;string major;public:student();void set();void modify();void display()const;student();抽象:简化问题,忽略非本质问题,目的是隐藏实现细节和内部数据结构,提高复用的力度和粒度 用户定义,用以表示应用问题的数据模型 由基本的数据类型组成,并包括一组相关的服务(或称操作)信息隐蔽和数据封装,使用与实现相分离抽象数据类型(ADTs:Abstract Data Types)数据类型的定义只涉及数据模型的逻辑特征,不涉及该模型的具体实现细节 不管内部采用什么技术方法来实现这个抽象数据类型,只要模型的数学特性不变,都不会影响它的外部使用。抽象的目的就是让人们集中精力把握问题的实质,研究解决问题的算法核心,抛开繁复的实现细节,从而使得问题得到简化 抽象可以按照一定的层次逐步提高,抽象的程度,层次越高细节就越少,使用就越方便。抽象数据类型(ADTs:Abstract Data Types)抽抽象象数数据据类类型型查找插入删除修改学 生 记 录 由三元组表示ADT抽象数据类型名数据对象D数据关系S数据操作P 用数学方法定义对象集合和运算集合,仅通过运算的性质刻画数据对象,独立于计算机中的可能的表示方法 本课程中用C的template表示抽象数据类型 模板重点描述数据元素之间的关系、存储方式和对数据的操作ADT的格式template class dataList private:Type*Element;int ArraySize;void Swap(const int m1,const int m2);int MaxKey(const int low,const int high);模板参数为数据表中元素的类型数据表模板类的定义定义数据结构的取值类型和取值空间定义数据结构存储方式public:dataList(int size=10):ArraySize(size),Element(new Type Size)dataList()delete Element;void Sort();friend ostream&operator (ostream&outStream,const datalist&outList);friend istream&operator (istream&inStream,const datalist&inList);#endif定义对数据的操作 模板重点描述数据元素之间的关系、存储方式和对数据的操作 只是一种概念类型,不能进行编译 抽象数据类型只有实现之后才能被使用 实现过程要设计存储结构、编写实现源程序 是使用者和编程者之间的约定形式ADT形式化说明本课程中编程使用的本课程中编程使用的C+C+技术技术动态存储分配动态存储分配深复制和浅复制深复制和浅复制模板模板STLSTLC C中中malloc()malloc()和和free()free()C+C+中中newnew和和deletedeletenewnew按指定类型自动分配足够的空间按指定类型自动分配足够的空间newnew自动返回指定类型的指针自动返回指定类型的指针newnew和和deletedelete可以重载可以重载动态存储空间的管理需要注意的问题动态存储空间的管理需要注意的问题C+C+没有垃圾收集机制,不再使用的动态存储没有垃圾收集机制,不再使用的动态存储空间一定要由程序员采用空间一定要由程序员采用deletedelete方式回收方式回收C+C+的动态存储分配的动态存储分配例例1 1:int*int*ip ip=new int;=new int;if(if(ip ip=0)=0)cerrcerr “Memory not allocated”“Memory not allocated”endlendl;例例2 2:point*p=new point 100;point*p=new point 100;delete delete p;p;C+的动态存储分配deletedelete的指针只能是的指针只能是newnew申请到的申请到的如果是数组,必须用如果是数组,必须用delete delete 删除删除深复制和浅复制I内部数据:蕴含在结构之中,例如:内部数据:蕴含在结构之中,例如:class Teacherclass Teacher string*string*firstnamefirstname;string*string*lastnamelastname;int int employeeNumemployeeNum;I外部数据:位于结构之外,通过指针加以访问外部数据:位于结构之外,通过指针加以访问默认复制是复制指针而不是指针指向的数据默认复制是复制指针而不是指针指向的数据n浅复制:指针的复制浅复制:指针的复制n深复制:复制指针所指向的数值深复制:复制指针所指向的数值需要重载复制运算符需要重载复制运算符String*fiirstnameString*lastnameint employeeNum模板(模板(TemplateTemplate)I模板:允许编写对任意类型均有效的函数例程,模板:允许编写对任意类型均有效的函数例程,而无需知道具体的类型而无需知道具体的类型I模板分类:函数模板模板分类:函数模板类模板类模板I模板的使用:模板的使用:在编写与类型无关的算法或所谓的通用算法时在编写与类型无关的算法或所谓的通用算法时采用模板的方式编写程序可以取得更广泛的应采用模板的方式编写程序可以取得更广泛的应用效果用效果函数模板可以用来创建一个通用功能的函数,函数模板可以用来创建一个通用功能的函数,以支持多种不同形参,进一步简化重载函数的以支持多种不同形参,进一步简化重载函数的函数体设计。函数体设计。定义形式:定义形式:模板类定义中只有一个函数的定义模板类定义中只有一个函数的定义定义方法:定义方法:template 函数定义函数模板的定义用模板定义用于排序的数据表用模板定义用于排序的数据表(dataListdataList)类类template class dataList private:Type*Element;int ArraySize;void Swap(const int m1,const int m2);int MaxKey(const int low,const int high);声明一个模版类public:dataList(int size=10):ArraySize(size),Element(new Type Size)dataList()delete Element;void Sort();friend ostream&operator (ostream&outStream,const datalist&outList);friend istream&operator (istream&inStream,const datalist&inList);template void dataList:Sort()/按非递减顺序对ArraySize个关键码/Element0ElementArraySize-1排序。for(int i=ArraySize-1;i 0;i-)int j=MaxKey(0,i);if(j!=i)swap(j,i);使用模板的选择排序算法的主函数使用模板的选择排序算法的主函数#includeinclude“selecttm.h”const intconst intSIZE=10;intintmain()dataListTestList(SIZE);cincin TestList;coutcout“Testing Selection Sort:n”TestList endlendl;TestList.Sort();coutcout“After sorting:n”TestList endlendl;returnreturn0;标准模板库标准模板库-STL STL 是是C+C+的一个的一个通用库通用库,它提供了许多大部分,它提供了许多大部分程序通用的组件,这些组件灵活有效,提高了编程程序通用的组件,这些组件灵活有效,提高了编程的效率。的效率。STL STL 组件都是模板。组件都是模板。-STLSTL提供了许多基本算法,数据结构,主要包括三提供了许多基本算法,数据结构,主要包括三方面:方面:ContainersContainersIteratorsIteratorsAlgorithmsAlgorithmsSTL(Standard Template Library)ContainersContainersSTLSTL容器的头文件,名字就是容器的类型名称容器的头文件,名字就是容器的类型名称1:#include /strings 1:#include /strings 2:#include /arrays 2:#include /arrays 3:#include /cyclic doubly linked lists3:#include /cyclic doubly linked lists4:#include /hybrid list/array 4:#include /hybrid list/array 5:#include /queue 5:#include /queue 6:#include /stack 6:#include /stack 7:#include 7:#include /bit /bit-vectors vectors 8 8:#include /general sets:#include /general sets 9 9:#include /associative arrays:#include /associative arrays1:1:#include#include /complex numbers/complex numbers 2:2:#include#include /numerical arrays/numerical arrays 3:3:#include#include /numerical algorithms/numerical algorithms 4 4:#include:#include /math functions/math functions 数值计算头文件STLSTL的扩展头文件的扩展头文件1:1:#include#include /hash set 2:2:#include#include /hash map/hash map 3:3:#include#include /singly linked list Listing/singly linked list Listing STLSTL中中iteratorsiterators提供了提供了ContainersContainers和和AlgorithmsAlgorithms之之间的接口,与指针相似。间的接口,与指针相似。例如:例如:itritr+、*itritr运算运算Iterators/Traversing a container using iterators string A=This is a string;string:iterator it;/create iteratorfor(it=A.begin();it!=A.end();+it)cout *it endl;STLSTL中中的的核心核心是算法。由是算法。由于于容器和算法之间通过容器和算法之间通过迭代迭代器器联联系系起来起来,所以算法可以,所以算法可以脱离脱离容器容器来来写写如排如排序算法序算法template class template void void sortsort(R RandomIteratorandomIterator beginbegin,R RandomIteratorandomIterator endend)template class template Comparatorvoidvoid sortsort(R RandomIteratorandomIterator beginbegin,R RandomIteratorandomIterator endend,Comparator Comparator lessThanlessThan)算法(算法(AlgorithmsAlgorithms)#include#include#include#include using namespace std;int main(int argc,char*argv)string s=This is a test;cout s endl;/replace spaces with hyphens replace(s.begin(),s.end(),-);cout s endl;/reverse the stringreverse(s.begin(),s.end();cout s endl;return EXIT_SUCCESS;n数据类型是高数据类型是高级语言中级语言中提供的基本数据存储和操提供的基本数据存储和操作的方法作的方法;n抽象数据类型是用抽象数据类型是用户户定定义义的,用的,用于解决于解决实实际问题际问题的的复合复合数据类型和操作方法数据类型和操作方法;n一一般般用数据对象、关系和操作三元组描述抽象数用数据对象、关系和操作三元组描述抽象数据类型据类型;n模板模板等等是需要是需要常常用的编程用的编程技术;技术;nSTLSTL是实是实际际应用应用中中要使用的数据类型。要使用的数据类型。小结

    注意事项

    本文(数据结构与算法设计PPT (2).pdf)为本站会员(刘静)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开