“第四十五天” 数据结构基本概念

2023-10-26 04:01

本文主要是介绍“第四十五天” 数据结构基本概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

     

  目前看的有关数据结构的课,估计这周就看完了,但感觉差很多,还是和c一样,这样过一下吧。但可能比较急,目前是打算争取寒假回家之前把四大件都先大致过一遍。

数据结构里面有很多新的定义和概念,学到现在,数据结构给我的感觉更像是,将生活中一些常用的模型抽象出来,然后用编程语言加以描述和实现对其处理,学习的也就是这个。一些感觉我已经知道的概念就不写了。

        

        数据结构是相互之间存在一种或多种特定关系的数据元素的集合。数据元素之间的关系就是结构。通常有四种基本结构:1、集合 ,2、线性结构,3、树形结构 ,4、图状结构或网状结构。

线性结构可以联想一下我们日常生活中的排队之类的,树形结构就是一对多那种,比如我们下棋,对于当前一步后面可以出现多种下法,图或者网就是多对多了,比如我们的路。

        对于结构定义中的“ 关系 ”实际上描述的是数据结构之间的逻辑结构,这个我云里雾里的,感觉大致应该是数据之间是通过何种方式产生关联的,然后数据结构在计算机中的表示(映像)称为数据的物理结构,也叫存储结构

数据:能够输入计算机且被计算机处理的各种符号的集合,比如我们这么多学生的信息啊之类的

数据元素:是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。也称为元素,记录或者结点,顶点。和上面比的话就是我们每一个学生的信息就是一个数据元素。                   

数据项  : 构成数据元素的不可分割的最小单位,我们每个的信息也可以在划分一下,比如学号,姓名,性别之类的,这些都是构成我们信息的数据项。

数据对象:性质相同的数据元素的集合。注意是数据元素,不是数据项。

数据元素之间的关系在计算机中有两种不同的表示方法:顺序映像和非顺序映像  ,对应的存储结构分别是顺序存储结构和链式存储结构 ,数组就是一种顺序存储结构,数据之间彼此是相互靠近的,而链式存储结构,数据和数据并不一定是靠近的,而且感觉基本是不可能靠近的,所以对于链式存储,要想实现数据的关联,就需要存储对于关联数据的地址以达到访问或者操作的目的。

抽象数据类型 :一个数学模型以及定义在该模型上的一组操作。

抽象数据类型里面有三个东西,分别是 数据对象 ,数据关系 ,基本操作。

ADT  抽象数据类名
{数据对象:(数据对象的定义)数据关系:(数据关系的定义)基本操作:(基本操作的定义)
}

算法是对特定问题求解步骤的一种描述,它是指令的有限序列,有五个重要特性:

1、有穷性,在进行有限操作之后可以结束,且每一步都可以在有穷时间内完成;

2、确定性:算法中的每一条指令必须有确切的含义,有唯一的执行路径;

3、可行性:算法中描述的操作都是可以通过已经实现的基本运算执行有限次来实现的;

4、输入:有零或多个输入,取自某个特定的对象的集合。

5、输出:有一个或多个输出,输出和输入有着某些特定的关系;

然后还有关于时间复杂度和空间复杂度的概念分别用来描述算法基本操作重复执行的次数和算法所需存储空间的度量,也就是看看这个算法算的快不快以及占地方大不大,毕竟人的时间有限,电脑空间有限,是用来衡量一个算法是否优秀的。

新东西,布尔值的变量并不算赋值好像,更像是根据所得值进行判断,然后给自身一个值,非零值视为真,给自身赋值为1 ,零值视为假,给自己赋值 0 .

这篇关于“第四十五天” 数据结构基本概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/285409

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

【机器学习】高斯网络的基本概念和应用领域

引言 高斯网络(Gaussian Network)通常指的是一个概率图模型,其中所有的随机变量(或节点)都遵循高斯分布 文章目录 引言一、高斯网络(Gaussian Network)1.1 高斯过程(Gaussian Process)1.2 高斯混合模型(Gaussian Mixture Model)1.3 应用1.4 总结 二、高斯网络的应用2.1 机器学习2.2 统计学2.3

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre

Python 内置的一些数据结构

文章目录 1. 列表 (List)2. 元组 (Tuple)3. 字典 (Dictionary)4. 集合 (Set)5. 字符串 (String) Python 提供了几种内置的数据结构来存储和操作数据,每种都有其独特的特点和用途。下面是一些常用的数据结构及其简要说明: 1. 列表 (List) 列表是一种可变的有序集合,可以存放任意类型的数据。列表中的元素可以通过索

【Rocketmq入门-基本概念】

Rocketmq入门-基本概念 名词解释名称服务器(NameServer)消息队列(Message Queue)主题(Topic)标签(Tag)生产者(Producer)消费者(Consumer)拉取模式(Pull)推送模式(Push)消息模型(Message Model) 关键组件Broker消息存储工作流程 名词解释 名称服务器(NameServer) 定义: 名称服务器

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo