数据结构与算法(Java版) | 线性结构和非线性结构

news2024/9/21 2:47:11

之前,我们说过,数据结构是算法的基础,因此接下来在这一讲我就要来给大家重点介绍一下数据结构了。

首先,大家需要知道的是,数据结构包括两部分,即线性结构和非线性结构。知道这点之后,接下来我势必就要来为大家分别进行详细介绍了,下面咱们不妨先来看一下线性结构。

线性结构

关于线性结构,下面我一共罗列出来了五点需要大家进行掌握。

第一点,线性结构作为最常用的数据结构,其特点是数据元素之间存在一对一的线性关系。就拿我们学过的一维数组来说,大家应该知道每一个下标就唯一对应一个值吧,而这就叫做一对一的线性关系,因此一维数组就是一种典型的线性结构,当然,除了一维数组之外,链表也是一种线性结构。

第二点,线性结构有两种不同的存储结构,即顺序存储结构和链式存储结构

第三点,顺序存储的线性表称为顺序表,且顺序表中的存储元素是连续的。例如数组,它就是一个顺序表,不必我说,大家也都知道它里面的存储元素是连续的吧!

注意,这里的连续指的是存储元素之间的地址是连续的,为什么我会这么说呢,因为顺序表在内存中是以连续存储的方式进行存储的,而这也就是说,一旦在内存中为顺序表分配好了存储空间,那么它里面的元素就会被存储在一块连续的内存空间中,自然这些存储元素之间的地址就是连续的了。

第四点,链式存储的线性表称为链表,与顺序表不同的是,链表中的存储元素不一定是连续的,且元素节点中存放的是数据元素以及相邻元素的地址信息

初次谈起链表这种存储结构,相信大家可能会一头雾水,如果你没学过的话,不过,没学过也没关系,因为我们这套系列教程后面就会给大家介绍到,比方说单链表、双向链表等等。当然,这里我们说的是链表,既然说的是链表,那它肯定就与顺序表不同了,具体点说,就是链表中的存储元素就不一定是连续的了,也就是说有可能是连续的,也有可能是不连续的,感觉我说了句废话,哈哈哈😂!而且,链表中的每一个存储元素你都可以看作是一个节点,至于每一个节点中存放的是什么,我相信大家也都知道了,即数据元素以及相邻元素的地址信息。

看到这里,我相信大家已经已然知晓这一点了,即链表中节点与节点之间是通过地址来相互连接的,而且它们之间的地址还不一定连续。正是因为节点与节点之间相互连接的地址不一定连续,所以链表才有了这样一个好处,即可以充分的利用碎片内存。

第五点,线性结构常见的有数组、队列、链表和栈,这里大家先知道有这四种常见的线性结构就行,后面我再来给大家进行详细介绍啊!

说起数组,相信大家对其应该是再熟悉不过的了,不过你有可能不知道的是,数组也可以分好多种哟,例如稀疏数组;至于队列嘛,它也有单向队列、环形队列之分;链表就更是如此了,它同样也有单链表、环形链表、双向链表之分;至于栈嘛,大家可能会感觉有点陌生,不过它也有不同的实现方式,例如可以用数组来实现,或者也可以用链表来实现。凡此种种,后面我都会给大家详细介绍到。

最后,再给大家提个醒吧,就是大家学完数据结构之后,别人问你线性结构有哪些,你可不要连最基本的线性结构包括哪些都答不上来哟,你得答上来才行,否则这不就是出大问题了嘛😭!

非线性结构

与线性结构相反,非线性结构,其数据元素之间可能就不存在那种一对一的线性关系了,或者亦可说至少已经不是那种一对一的线性关系了。

例如,一个节点下面不仅可以有左节点,而且还可以有右节点,如下所示。

在这里插入图片描述

甚至,它下面可能还有第三个节点,而这就叫做多路查询树。

在这里插入图片描述

当然,如果大家这块听得不是太明白,那么也不打紧,因为后面我就会给大家详细介绍到。

上面我们讲到线性结构常见的有数组、队列、链表和栈,那么非线性结构又具体包括哪些呢?非线性结构包括二维数组、多维数组、广义表、树结构以及图结构

关于数组,尤其是二维数组,我想大家对其应该是再熟悉不过的了,而且马上我们就会讲到它,当然,讲二维数组我们会重点讲稀疏数组,至于稀疏数组是什么,大家下一讲就会知道;至于树结构和图结构,它俩是我们用的最多的非线性结构,而且由它俩还引申出来了很多很多算法,因此它俩将是我们后续学习的一个重点,到时候学的时候大家可要打起万分精神来学哟!

至此,关于线性结构和非线性结构的介绍,我就给大家讲到这里了,希望经过我的讲解,大家能对线性结构和非线性结构有一个最基本的认识。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/358042.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

flex一把梭

flex 使用display:flex,可以让一个元素变成弹性容器(flex容器),该元素中的直接子元素成为弹性项(flex项) flex-direction 使用flex-direction可以控制flex容器的主轴的方向:垂直(…

躬身入局,干货分享,2023年春招后端技术岗(Python)面试实战教程,Offer今始为君发

早春二月,研发倍忙,杂花生树,群鸥竟飞。为什么?因为春季招聘,无论是应届生,还是职场老鸟,都在摩拳擦掌,秣马厉兵,准备在面试场上一较身手,既分高下&#xff0…

Allegro如何让测量时显示双单位操作指导

Allegro如何让测量时显示双单位操作指导 在用Allegro做PCB设计的时候,时常会需要使用到测量命令,通常显示的一个单位,比如mil,如下图 当希望除了看到mil单位的值,又同时能够看到mm单位的值,省去换算的时间 具体设置如下 点击Setup点击User Preference

Linux服务:Nginx服务部署及基础配置

目录 一、Nginx介绍 1、Nginx简介 2、I/O模型相关概念 3、Nginx事件驱动模型 二、部署Nginx 1、yum部署Nginx 2、编译安装Nginx 三、Nginx使用 1、基础使用 2、nginx信号 四、web服务选择及优化 1、Nginx与Apache对比 2、Nginx服务调优 一、Nginx介绍 1、Nginx简…

SAP ABAP

方法一: REPORT ZDCH_09_TEST2. ************************************************************************ * DATEN DEFINITION * *********************************************************************…

【数据结构】二叉树-堆实现及其堆的应用(堆排序topK问题)

文章目录一、堆的概念及结构二、堆的实现1.结构的定义2.堆的初始化3.堆的插入4.堆的向上调整5.堆的删除6.堆的向下调整7.取出堆顶元素8.返回堆的元素个数9.判断堆是否为空10.打印堆中的数据11.堆的销毁三、完整代码1.Heap.h2.Heap.c3.test.c四、堆排序1.堆排序2.建堆3.选数4.完…

Shopee、ebay、亚马逊等跨境卖家了解测评的一篇干货

随着时代的发展,大家越来越喜欢网购,国外也有亚马逊、沃尔码、阿里国际、速卖通、ebay、shopee、Lazada、ozon、temu等等,而国外这些平台也有很大的市场,跨境电商也随时诞生,而当今社会环境实体生意越来越难做&#xf…

DAMA认证|数据治理产业上规模需要做到“三化”

数据治理是开启数据安全体系化建设的第一步,需要从产业层面做大做强,支撑数据安全整体框架,为数据流通提供安全保障,推动促进数字化产业进一步发展。 规模化发展是数据治理产业的瓶颈,行业数字化业务的复杂性和过多的定…

k8s安装tekton,编写task

文章目录一、官方安装二、国内资源安装安装tekton安装dashboard安装CLI三、demo编写task.yaml编写taskRun.yaml使用tkn命令查看参考文章一、官方安装 地址:https://tekton.dev/docs/installation/pipelines/#installing-tekton-pipelines-on-kubernetes 注意&#…

Spring MVC 源码之MultipartResolver 组件

MultipartResolver 组件,内容类型( Content-Type )为 multipart/* 的请求的解析器,主要解析文件上传的请求。例如,MultipartResolver 会将 HttpServletRequest 封装成 MultipartHttpServletRequest 对象,便于获取参数信息以及上传…

【NVMEM子系统】二、NVMEM驱动框架

个人主页:董哥聊技术我是董哥,嵌入式领域新星创作者创作理念:专注分享高质量嵌入式文章,让大家读有所得!文章目录1、前言2、驱动框架3、源码目录结构4、用户空间下的目录结构1、前言 NVMEM SUBSYSTEM,该子系…

视频片段怎么做成gif图?快试试这2种方法

动态gif图片作为当下非常常用的表情包,其丰富的内容生动的画面深受大众喜爱。那么,当我们想要将电影或是电视剧中的某一片段做成gif动态图片的时候,要如何操作呢?接下来,给大家分享两招视频转化gif的小窍门–使用【GIF…

【力扣-Python-1】两数之和(easy)

https://leetcode.cn/problems/two-sum/题目描述给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值 target 的那两个整数,并返回它们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答…

uboot下实现U盘自动升级程序的思路分析(基于USB系统、eMMC系统、FAT32文件系统)

1、常见的升级方式 1.1、应用程序升级 优点:在图形化界面操作,只需要选中升级文件并点击升级即可,操作简单; 缺点:应用程序必须能正常启动,当程序出现bug就不能升级,可靠性差; 总结…

旺店通与金蝶云星空对接集成采购入库单接口

旺店通旗舰奇门与金蝶云星空对接集成采购入库单查询连通销售退货新增V1(12-采购入库单集成方案-P)数据源系统:旺店通旗舰奇门旺店通是北京掌上先机网络科技有限公司旗下品牌,国内的零售云服务提供商,基于云计算SaaS服务模式,以体系化解决方案…

Prometheus集群分布式架构浅析

集群行为是一种常见于自然界中鱼群、鸟群、蜂群等低等群居生物的集体行为,受此启发形成了无人机集群的概念。无人机集群不是多无人机间的简单编队,而是通过必要的控制策略使之产生集群协同效应,从而具备执行复杂多变、危险任务的能力。目前无…

【C++】AVLTree——高度平衡二叉搜索树

文章目录一、AVL树的概念二、AVL树节点的定义三、AVL树的插入四、AVL树的旋转1.左单旋2.右单旋3.左右双旋4.右左双旋五、进行验证六、AVLTree的性能个人简介📝 🏆2022年度博客之星Top18;🏆2022社区之星Top2;的🥇C/C领域优质创作者…

JVM类加载子系统

1、类加载子系统在内存结构中所处的位置通过内存结构图,我们先知道类加载子系统所处的位置,做到心中有图。2、类加载器作用类加载器子系统负责从文件系统或者网络中加载Class文件,class文件在文件开头有特定的文件标识。ClassLoader只负责cla…

anaconda创建环境为空、修改默认环境位置

无论是用navigator还是命令行创建环境都无法指定python版本conda create -n test python3.9其实就是没有路径,添加几个镜像就好:conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free/ conda config --add channels ht…

BUUCTF-[安洵杯 2019]crackMe1

题目下载:下载 这道题涉及到SM4加密和变表base64。 SM4简单了解:SM4算法过程_不是小白才怪的博客-CSDN博客_sm4算法 先运行一下程序, 发现有一个Messagebox,并且内容是hooked。 载入IDA,使用IDA的插件Findcrypt查…