计算机二级c语言公共基础知识教程,计算机二级C语言 公共基础知识教程.doc

第 PAGE 1 页 共 NUMPAGES 25 页

`

第1章 数据结构与算法

§1.1 算法的复杂度

1. 算法的基本概念

①.算法:即解题方案的准确而完整的描述【注意:算法不等于程序,也不等于计算方法,通常,程序的编制不可能优于算法的设计】

②.利用计算机算法为计算机解题的过程实际上是在实施某种算法。

(1)算法的基本特征

算法一般具有4个基本特征:可行性、确定性、有穷性(包括精度要求确定的计算过程和合理的执行时间的含义)、拥有足够的情报。

(2)算法的基本要素

①.对数据对象的运算和操作

计算机算法就是计算机能处理的操作所组成的指令序列。通常,计算机可以执行的基本操作是以指令的形式描述的,一个计算机系统能执行的所有指令的集合称为该计算机系统的指令系统。其中基本的运算和操作包括:算术运算、逻辑运算、关系运算、数据传输(赋值、输入、输出等)。

②.控制结构:算法中各操作之间的执行顺序称为算法的控制结构。

ⅰ.描述算法的工具通常有:传统流程图、N—S结构化流程图、算法描述语言。

ⅱ.一个算法的3种基本控制结构:顺序结构、选择结构、循环结构。

(3)算法基本设计方法

算法基本设计方法:列举法、归纳法、递推(逐成分解)、递归、减半递推技术、回溯法。

2. 算法复杂度

算法复杂度包括时间复杂度和空间复杂度。注意两者的区别,不要混淆,见表1-1

§1.2 数据结构

1.2.1 逻辑结构和存储结构

1. 数据结构的基本概念

(1)数据结构:指相互有关联的数据元素的集合。

(2)数据处理:指对数据集合中的各元素以各种方式进行运算,包括插入、删除、查找、更改等运算、也包括对数据元素进行分析。

(3)数据结构研究的3个方面

①.数据集合中各数据元素之间所固有的逻辑关系,即数据的逻辑结构;

②.在对数据进行处理时,各数据元素在计算机中的存储关系,即数据的存储结构;

③.对各种数据结构进行的运算。

2. 数据的逻辑结构

数据的逻辑结构是对数据元素之间的逻辑关系的描述,它可以用一个数据元素的集合和定义在此集合中的若干关系来表示。数据的逻辑结构有两个要素:一是数据元素的集合,通常记为D;二是D上的关系,它反映了数据元素之间的前后件关系,通常记为R。一个数据结构可以表示成:B=(D,R)

其中,B表示数据结构。为了反映D中各数据元素之间的前后件关系,一般用二元组来表示。在数据处理领域中,通常把数据元素之间的这种固有的关系简单地用前后件关系(或直接前驱或直接后继关系)来描述。例如,假设a与b是D中的;两个数据,则二元组(a,b)表示a是b的前件,b是a的后件

例如,如果把一年四季看作一个数据结构,则可表示成:B =(D,R)

D ={春季,夏季,秋季,冬季}

R ={(春季,夏季),(夏季,秋季),(秋季,冬季)}

3. 数据的存储结构

数据的逻辑结构在计算机存储空间中的存放形式称为数据的存储结构(也称数据的物理结构)。

由于数据元素在计算机存储空间中的位置关系可能与逻辑关系不同,因此,为了表示存放在计算机存储空间中的各数据元素之间的逻辑关系(即前后件关系),在数据的存储结构中,不仅要存放各数据元素的信息,还需要存放各数据元素之间的前后件关系的信息。

一种数据的逻辑结构根据需要可以表示成多种存储结构,常用的存储结构有顺序、链接、索引等存储结构。

顺序存储方式主要用于线性的数据结构,它把逻辑上相邻的数据元素存储在物理上相邻的存储单元里,结点之间的关系由存储单元的邻接关系来体现。

链式存储结构就是在每个结点中至少包含一个指针域,用指针来体现数据元素之间逻辑上的联系。

1.2.2 数据结构的图形表示

父亲一个数据结构除了用二元关系表示外,还可以直观地用图形表示。在数据结构的图形表示中,对于数据集合D中的每一个数据元素用中间标有元素值的方框表示,一般称为数据结点,并简称为结点;为了进一步表示各数据元素之间的前后件关系,对于关系R中的每一个二元组,用一条有向线段从前件结点指向后向结点。

父亲

例如,一年四季的数据结构可以用如图的图形表示

女儿儿子

女儿

儿子

又如,反映家庭成员间辈分关系的数据结构可以用如图的图形表示

在数据结构中,没有前件的结点称为根结点;没有后件的结点称为终端结点(也称叶子结点)。例如,在数据结构一年四季中,“春”所在的结点(简称为结点“春”,下同)为根结点,结点“冬”为终端结点。通常,一个数据结构中的元素结点可能是在动态变化的。根据需要或在处理过程中,可以在一个数据结构中增加一个新结点(称为插入运算),也可以删除数据结构中某个结点(称为删除运算)插入与删除是对数据结构的两种基本运算。除此之外,对数据结构的运算还有查找、分类

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值