欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

第1章 绪论

发布时间:2023/12/4 52 豆豆
生活随笔 收集整理的这篇文章主要介绍了 第1章 绪论 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

《数据结构》学习笔记

第1章 绪论

1.1 数据结构的研究内容

计算机计算数值时,一般经过一下步骤:
1.从具体问题抽象出数学模型(实质是分析问题)。
2.设计一个解次数学模型的算法。
3.编写程序,进行测试、调试,直到问题解决。

数据结构要研究非数值计算问题,非数值计算问题无法用数学方程建立数学模型。

1.2 基本概念和术语

1.2.1
数据项(Data Item):是组成数据元素、有独立含义的、不可分割的最小单位。
数据元素(Data Element):是数据的基本单位,也称为元素、记录等;用于完整地描述一个对象。
数据对象(Data Object):是性质相同的数据元素的集合,只要集合内元素的性质均相同,都可称之为一个数据对象;是数据的一个子集。
数据(Data):是客观事物的符号表示,是所有能输入到计算机中并被计算机程序处理的符号的总称。
(数据项<数据元素<数据对象<数据)

1.2.2 数据结构

数据结构(Data Structure)是相互之间存在一种或多种特定关系的数据元素的集合。数据结构是带“结构”的数据元素的集合,“结构”就是指元素之间存在的关系。

-1.逻辑结构
从逻辑关系上描述数据,与数据的存储无关,是独立于计算机的。
分为两个要素:

  • 数据元素
  • 关系
  • 常见的四类基本结构:
    图1.3
    (1)集合结构:数据元素之间除了“属于同一个集合”的关系外,别无其它关系。
    (2)线性结构:数据元素之间存在一对一的关系。
    (3)树结构:数据元素之间存在一对多的关系。
    (4)图结构或网状结构:数据元素之间存在多对多的关系。

    -2. 存储结构
    数据对象在计算机中的存储表示称为数据的存储结构,也称为物理结构。
    (1)顺序存储结构:借助元素在存储器中的相对位置来表示数据元素之间的逻辑关系,通常借助数组来描述。要求所有元素依次存放在一片连续的存储空间中。
    表1.2

    (2)链式存储结构:无需占用一整块存储空间。给每个结点附加指针字段,用于存放后继元素的存储地址,从而来表示结点之间的关系。
    图1.5

    1.2.3 数据类型和抽象数据类型
    -1. 数据类型(Data Type)
    是高级程序设计语言中的一个基本概念,在程序设计语言中,每一个数据都属于某种数据类型。类型明显或隐含地规定来数据的取值范围,存储方式以及允许进行的运算,数据类型是一个值的集合和定义在这个值集上的一组操作的总称。

    -2. 抽象数据类型(Abstract Data Type, ADT)
    一般指由用户定义的、表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称,具体包括三部分:数据对象、数据对象上关系的集合、数据对象的基本操作的集合。
    在高级语言中,则给出更高一级的数据抽象,出现了数据类型,如整形、实型、字符型等,可以进一步利用这些类型构造出线性表、栈、队列、树、图等复杂的抽象数据类型。

    1.3 抽象数据类型的表示与实现
    表示和实现抽象数据类型,最好用面向对象的方法。

    1.4 算法和算法分析

    1.4.1 算法的定义及特性
    算法(Algorithm)是为了解决某类问题而规定的一个有限长的操作序列。五个重要特征:

  • 有穷性
  • 确定性
  • 可行性
  • 输入
  • 输出
  • 1.4.2 评价算法优劣的基本标准

  • 正确性
  • 可读性
  • 健壮性
  • 高效性
  • 1.4.3 算法的时间复杂度
    算法效率分析的目的是看算法实际是否可行,并在同一问题存在多个算法时,可进行时间和空间性能上的比较,以便从中挑选出较优算法。

    -1. 问题规模和语句频度。
    问题规模:算法求解问题输入量的多少,是问题大小的本质表示,一般用整数n表示。n越大算法的执行时间越长。
    语句频度(Frequency Count):一条语句的重复执行次数。

    算法中基本语句重复执行的次数是问题规模n度某个函数f(n);算法的时间复杂度为:T(n)=O(f(n))
    算法执行时间的增长率和f(n)的增长率相同,称做算法的渐进时间复杂度,简称时间复杂度(Time Complexity)。
    为了方便比较不同算法的时间效率,我们仅比较它们的数量级(最高次幂),数量级越小,算法越优。

    -2. 计算时间复杂度基本方法

  • 找出语句频度最大的语句(也就是执行次数最多的语句)。
  • 执行次数表示为关于问题规模n的某个函数f(n)。
  • 取其数量级(最高次幂)。
  • -3. 算法的时间复杂度分析举例
    例1.

    x=0, y=0; #执行1for(int k=0; k<n; k++) #从0~n,结束循环要多判断一次,所以执行n+1次x++; #从0~n,执行n次 for(int i=0; i<n; i++) #执行n+1for(int j=0; j<n; j++) #外层没执行一次,内层执行n+1次,所以n(n+1)次y++; #n乘以n次

    上述代码,数量级最大的为二次方,所以T(n)=O(n*2)

    例2.

    例3.

    例4.

    1.4.4 算法的空间复杂度

    …持续修改完善中

    总结

    以上是生活随笔为你收集整理的第1章 绪论的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。