数据结构教程 第一课 数据结构的基本概念和术语

本课主题:数据结构的基本概念和术语

教学目的:了解数据结构的基本概念,理解常用术语

教学重点:基本概念:数据与数据元素

教学难点:数据元素间的四种结构关系。

授课内容:

一、数据、数据元素、数据对象、数据结构的定义

1、数据的定义

定义一:数据是客观事物的符号表示。

学号 姓名 语文 数学 C语言
6201001 张三 85 54 92
6201002 李四 92 84 64
6201003 王五 87 74 73
6201004        
...        

例:张三的C语言考试成绩为92分,92就是该同学的成绩数据。

定义二:能输入到计算机中并被计算机程序处理的符号的总称。

例:图像、声音等。

总结:现实世界信息的分析、复制、传播首先要符号化,这样才便于处理,尤其是便于计算机的处理。家长、社会要了解一个学生的学习成绩和能力,要看他的学习档案,而学习档案即是说明该学生学习情况的数据。

2、数据元素、数据项

数据元素是数据的基本单位,它也可以再由不可分割的数据项组成。如图示:

3、数据对象

是性质相同的数据元素的集合。如上例:一个班级的成绩表可以看作一个数据对象。

4、数据结构

定义一、数据元素集合(也可称数据对象)中各元素的关系。

定义二、相互之间存在特定关系的数据元素集合。

数据结构的种类:

  特征 示例
集合 元素间为松散的关系
线性结构 元素间为严格的一对一关系 如上面的成绩表中各元素
树形结构 元素间为严格的一对多关系
图状结构(或网状结构) 元素间为多对多关系

数据结构的形式定义:

数据结构名称=(D,S)

其中D为数据元素的有限集,S是D上关系的有限集

逻辑结构   “数据结构”定义中的“关系”指数据间的逻辑关系,故也称数据结构为逻辑结构。
存储结构   数据结构在计算机中的表示称为物理结构。又称存储结构。
顺序存储结构
链式存储结构

存储结构详解:

计算机中存储信息的最小单位:位,8位为一字节,两个字节为一字,字节、字或更多的二进制位可称为位串。在逻辑描述中,把位串称为元素或结点。

当数据元素由若干数据项组成时,位串中对应于各个数据项的子位串称为数据域(Data Field)。

例:上述成绩表数据用C语言的结构体数组classonestu[50]来存储:

struct stu {
int stuno;/*数据项,也称stu位串中的一个子位串,或叫做数据域*/
char name[20];
int maths;
int language;
int c_language;
} classonestu[50];

二、数据类型

1、定义:数据类型是一个值的集合和定义在这个值集上的一组操作的总称。

例:C语言中的整型,其内涵为一定范围的自然数集合,及定义在该集合上的加减乘除及取模、比较大小操作。而实型则无取模操作。当然整型也不需四舍五入。

2、数据类型的种类:

  特征
原子类型 值在逻辑上不可分解 int float
结构类型 值由若干成分按某种结构组成 struct stu

数据类型封装了数据存储与操作的具体细节。

三、总结

数据->数据元素

具有特定关系的数据元素集合->数据结构

数据结构的逻辑表示与物理存储->逻辑结构与存储结构

人们不仅关心数据的逻辑结构、存储结构,还关心数据的处理方法(算法)与处理结果->数据类型

数据类型->分类

时间: 2025-01-30 07:27:51

数据结构教程 第一课 数据结构的基本概念和术语的相关文章

Hinton 机器学习教程 第一课汉化版完整放送!

作为 AI 从业者,想必你和小编一样都有过类似的经历. 下定决心想要钻研机器学习类的课程,不仅要搞定学术理论,还得应对英语所带来的难题. 为了让广大 AI 青年们不再为英语所累,快速进入学习状态,雷锋网推出了深度学习大牛 Geoffrey Hinton 的<Neutral Network for Machine Learning>中文系列视频课程.本次课程来源于 Hinton 2012 年在多伦多大学的授课实录,适合于对 Machine Learning 有一定基础的同学来进一步学习研究.PS

JavaScript进阶教程(第一课)第1/3页_基础知识

欢迎您继续学习Javascript进阶教程.在此之前我们已经学习了Javascript初级教程.在这一阶段的学习中我们将继续学习在上次的教程中还没有来得及谈及的问题.我还将向你们展示Javascript的许多神奇功能,使你能够制作真正对多媒体应用程序.     以下是我们将涉及的内容:     给变量赋值     If-then语句     For和while循环     编写你自己的函数     打开及控制窗口     读写HTML 表单     应用数组     控制图片转换     如果这

数据结构教程 第二课 抽象数据类型的表示与实现

本课主题: 抽象数据类型的表示与实现 教学目的: 了解抽象数据类型的定义.表示和实现方法 教学重点: 抽象数据类型表示法.类C语言语法 教学难点: 抽象数据类型表示法 授课内容: 一.抽象数据类型定义(ADT) 作用:抽象数据类型可以使我们更容易描述现实世界.例:用线性表描述学生成绩表,用树或图描述遗传关系. 定义:一个数学模型以及定义在该模型上的一组操作. 关键:使用它的人可以只关心它的逻辑特征,不需要了解它的存储方式.定义它的人同样不必要关心它如何存储. 例:线性表这样的抽象数据类型,其数学

数据结构教程 第九课 循环链表与双向链表

本课主题: 循环链表与双向链表 教学目的: 掌握循环链表的概念,掌握双向链表的的表示与实现 教学重点: 双向链表的表示与实现 教学难点: 双向链表的存储表示 授课内容: 一.复习线性链表的存储结构 二.循环链表的存储结构 循环链表是加一种形式的链式存储结构.它的特点是表中最后一个结点的指针域指向头结点. 循环链表的操作和线性链表基本一致,差别仅在于算法中的循环条件不是p或p->next是否为空,而是它们是否等于头指针. 三.双向链表的存储结构 提问:单向链表的缺点是什么? 提示:如何寻找结点的直

C#教程第一课:简单的欢迎程序

程序|教程 本节课通过介绍几个简单的程序,使得你对C#有所入门.本节程要达到如下几个目的:1.理解一个C#程序的基本结构. 2.初步了解"名称空间"的概念. 3.初步了解"类"的概念. 4.了解"Main"方法所做的工作. 5.学会如何读取命令行输入信息. 6.学会使用控制台输入/输出 (I/O)语句. 1.清单1-1. 一个简单的欢迎程序Welcome.cs // Namespace Declarationusing System;// Pro

VBScript教程第一课 什么是 VBScript

vbscript|教程 Microsoft Visual Basic Scripting Edition 是程序开发语言 Visual Basic 家族的最新成员,它将灵活的 Script 应用于更广泛的领域,包括 Microsoft Internet Explorer 中的 Web 客户机 Script 和 Microsoft Internet Information Server 中的 Web 服务器 Script. 易学易用 如果您已了解 Visual Basic 或 Visual Bas

VBScript教程 第一课什么是VBScript_vbs

Microsoft Visual Basic Scripting Edition 是程序开发语言 Visual Basic 家族的最新成员,它将灵活的 Script 应用于更广泛的领域,包括 Microsoft Internet Explorer 中的 Web 客户机 Script 和 Microsoft Internet Information Server 中的 Web 服务器 Script. 易学易用 如果您已了解 Visual Basic 或 Visual Basic for Appli

php入门教程-第一课

/* 1.嵌入方法: 类似ASP的<%,PHP可以是<?php或者是<?,结束符号是?>,当然您也可以自己指定. 2.引用文件: 引用文件的方法有两种:require及include. require的使用方法如:require("MyRequireFile.php"); 这个函数通常放在PHP程序的最前面,PHP程序在执行前,就会先读入require所指定引入的文件,使它变成PHP程序网页的一部份.常用的函数,亦可以这个方法将它引入网页中. include使用

php入门教程第一课简单的PHP显示与嵌入PHP

 代码如下 复制代码 <html> <head> <title>第一个php教程程序</title> </head> <body> <?php echo "hello, 这是第一个php程序"; ?> </body> </html> 实例二 html代码讲解范例        代码如下 复制代码 <!doctype html public "-//w3c//dtd