- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构——绪论(C#)
1.1.5 数据结构和数据类型 1. 数据类型 在用高级程序语言(如C#语言)编写的程序中,通常需要对程序中出现的每个变量、常量或表达式,明确说明它们所属的数据类型。不同类型的变量,其所能取的值的范围不同,所能进行的操作不同。数据类型是一组性质相同的值的集合和定义在此集合上的一组操作的总称。 C#数据类型主要分为值类型和引用类型两大类。 2. 抽象数据类型 抽象数据类型(Abstract Data Type简写为ADT)指的是用户进行软件系统设计时从问题的数学模型中抽象出来的逻辑数据结构和逻辑数据结构上的运算,而不考虑计算机的具体存储结构和运算的具体实现算法。 抽象数据类型中的数据对象和数据运算的声明与数据对象的表示和数据运算的实现相互分离。 抽象数据类型可用(D,S,P)三元组表示。其中D是数据对象,S是D上的关系集,P是D中数据运算的基本运算集。其基本格式如下: ADT 抽象数据类型名 { 数据对象:数据对象的声明 数据关系:数据关系的声明 基本运算:基本运算的声明 } ADT 抽象数据类型名 【例1.6】 构造集合ADT Set,假设其中元素为字符串类型,遵循标准数学定义,成员包括Create(创建一个空集合)、Insert(插入一个元素)、Remove(删除一个元素)、IsIn(一个元素是否属于集合)。 另外定义一个实现集合运算的ADT TwoSet,成员包括Union(集合并)、IIntersection(集合交)和Difference(集合差)。 解:抽象数据类型Set和TwoSet的定义如下: ADT Set //集合的抽象数据类型 { 数据对象: data = {di | 1≤i≤n,di∈string}; //存放集合中元素 int n; //集合中元素个数 数据关系: 无 基本运算: public void Create(); //创建一个空的集合 public bool IsIn(string e); //判断e是否在集合中 public bool Insert(string e); //将元素e插入到集合中 public bool Remove(string e); //从集合中删除元素e } ADT Set ADT TwoSet //两个集合运算的抽象数据类型 { 数据对象: Set set1; //集合set1 Set set2; //集合set2 数据关系: 无 基本运算: public Set Union() //求两集合的并集 public Set IIntersection() //求两集合的交集 public Set Difference() //求两集合的差集 } 抽象数据类型有两个重要特征:数据抽象和数据封装。 所谓数据抽象,是指用ADT描述程序处理的实体时,强调的是其本质的特征、其所能完成的功能以及它和外部用户的接口(即外界使用它的方法)。 所谓数据封装,是指将实体的外部特性和其内部实现细节分离,并且对外部用户隐藏其内部实现细节。 1.2 算法及其描述 1.2.1 什么是算法 数据元素之间的关系有逻辑关系和物理关系,对应的运算有逻辑结构上的运算(抽象运算)和具体存储结构上的运算(运算实现)。算法是在具体存储结构上实现某个抽象运算。 确切地说,算法是对特定问题求解步骤的一种描述,它是指令的有限序列,其中每一条指令表示计算机的一个或多个操作。 算法具有以下五个重要的特性: 有穷性。指算法在执行有限的步骤之后,自动结束而不会出现无限循环,并且每一个步骤在可接受的时间内完成。 确定性。对于每种情况下执行的操作,在算法中都有确定的含义,不会出现二义性。并且在任何条件下,算法都只有一条执行路径。 可行性。算法的每条指令都是基本可执行的,意指借助纸、笔或计算机可以完成。 有输入。算法有零个或多个输入。 有输出。算法至少有一个或多个输出。 【例1.7】 考虑下列两段描述: (1)描述一 void exam1() { int n=2; while (n%2==0) n=n+2; Console.WriteLine(n={0},n); } (2)描述二 void exam2() { int x,y=0; x=5/y; Console.WriteLine(x={0},y={1},x,y); } 这两段描述均不能满足算法的特征,试问它们违反了哪些特性? 解:(1)其中while循环语句是一
您可能关注的文档
最近下载
- 附件视频监控存储升级项目要求及参数.doc VIP
- 【高中地理】区域地理:天气与气候,气温及分布规律课时2课件 2023-2024学年高二人教版(2019)地理选择性必修1.pptx VIP
- 2025年安全金融知识题库及答案.docx VIP
- 施工方案管理培训课件.docx VIP
- 【高中地理】区域地理:天气与气候,气温及分布规律课时1课件2023-2024学年高二人教版(2019)地理选择性必修1.pptx VIP
- 全新IMPA船舶物料指南(第7版)电子版.xls VIP
- 东方财富杯金融安全知识题库.docx VIP
- 2025年最新详版征信报告个人信用报告样板模板word格式新版可编辑.docx
- 孙氏太极拳(孙禄堂原著孙剑云整理).pdf VIP
- 车辆抵押借款合同范本协议(2025版).docx VIP
文档评论(0)