Java,数据结构与集合源码,数据结构概述

news2025/1/11 8:52:10

目录

数据结构概念:

数据结构的研究对象:

研究对象一,数据间逻辑关系:

研究对象二,数据的存储结构(或物理结构):

研究对象三:运算结构

数据结构的相关介绍:

链表:

单向链表:每个节点有记录下一个节点的信息

双向链表:每个节点有记录上一个节点的信息和记录上一个节点的信息。

二叉树:每个节点分别后来的两条节点,层层递进。

栈:(Stack)又称为堆栈或堆叠,是限制在表的一端进行插入和删除运算的线性表。

队列:(queue)


数据结构概念:

数据结构是程序设计优化的方法论研究数据的逻辑结构和物理结构以及它们之间的相互关系,并对这种结构定义相应的运算,目的是加快程序的执行速度、减少内存占用的空间。

数据结构的研究对象:

研究对象一,数据间逻辑关系:

①集合结构:数据结构之间的元素只有“同属于同一个集合”的关系。

②线性结构:数据结构中的元素存在一对一的相互关系。(体现:一维数组,链表,栈,队列)

③树形结构:数据结构中的元素存在一对多的相互关系。

④图形结构:数据结构中的元素之间存在多对多的相互关系。

研究对象二,数据的存储结构(或物理结构):

①顺序结构:使用一组连续的存储单元依次存储逻辑上相邻的各个元素。

优点:只需要申请存放数据本身的内存空间即可,支持下标访问,也可以实现随机访问。

缺点:必须静态分配连续空间,内存的利用率较低。插入或删除可能要移动大量元素,效率低。

②链式结构:不使用连续的空间存放结构的元素,而是为每一个元素构造一个节点。节点中除了存放数据本身之外,还需要存放指向下一个节点的指针。

优点:不采用连续的存储空间从而内存空间利用率更高,克服顺序存储结构中预知元素个数的缺点。插入或删除元素时不需要移动大量元素。

缺点:需要额外的空间来表达数据之间的逻辑关系,不支持下标访问和随机访问。

③索引结构:除了建立存储节点信息之外,还建立附加的索引表来记录每个元素节点的地址。索引表由若干索引项组成。索引项的一般形式是:(关键字,地址)

优点:用节点的索引号来来确定节点存储地址,检索速度快。

缺点:增加了附加的索引表,会占用较多的存储空间。在增加和删除数据时要修改索引表,会花费较多的时间。

④散列结构:根据元素的关键字直接计算出该元素的存储地址,又称Hash存储。

优点:检索、增加和删除节点的操作都很快。

缺点:不支持排序,一般比线性表存储需要更多的空间,并且记录的关键字不能重复。

研究对象三:运算结构

施加在数据上的运算包括运算的定义和实现。运算的定义是针对逻辑结构的,指出运算的功能。运算的实现是针对存储结构的,指出运算的具体操作步骤。

·分配资源,建立结构,释放资源

·插入和删除

·获取和遍历

·修改和排序

数据结构的相关介绍:

链表:

单向链表:每个节点有记录下一个节点的信息

模拟单向链表的代码如下:

package 数据结构.链表.单向链表;


public class Test
{
    public static void main(String[] args)
    {
        Node n1 = new Node("aaa");
        Node n2 = new Node("bbb");
        Node n3 = new Node("ccc");
        n1.next = n2;//记录下一个元素
        n2.next = n3;//记录下一个元素
        //尾节点没有下一个元素,next赋值为null
    }
}
class Node
{
    Object Data;//用于记录本节点的数据
    Node next;//用于记录下一个元素


    public Node()
    {
    }


    public Node(Object data)
    {
        Data = data;
    }
}

双向链表:每个节点有记录上一个节点的信息和记录上一个节点的信息。

模拟双向链表的代码如下:

package 数据结构.链表.双向链表;


public class Test
{
    public static void main(String[] args)
    {
        Node n1 = new Node("aaa");
        Node n2 = new Node("bbb");
        Node n3 = new Node("ccc");
        Node n4 = new Node("ddd");
        Node n5 = new Node("eee");
        n1.next = n2;//记录下一个元素
        //头节点没有上一个元素,prev赋值为null


        n2.next = n3;//记录下一个元素
        n2.prev = n1;//记录上一个元素


        n3.next = n4;//记录下一个元素
        n3.prev = n2;//记录上一个元素


        n4.next = n5;//记录下一个元素
        n4.prev = n3;//记录上一个元素


        n5.prev = n4;//记录上一个元素
        //尾节点没有下一个元素,next赋值为null
    }
}
class Node
{
    Object Data;//用于记录本节点的数据
    Node prev;//用于记录上一个元素
    Node next;//用于记录下一个元素


    public Node()
    {
    }


    public Node(Object data)
    {
        Data = data;
    }
}

二叉树:每个节点分别后来的两条节点,层层递进。

模拟二叉树的代码如下:

package 数据结构.二叉树;


public class Test
{
    public static void main(String[] args)
    {
        TreeNode t1 = new TreeNode("aaa");
        TreeNode t2 = new TreeNode("bbb");
        TreeNode t3 = new TreeNode("ccc");
        TreeNode t4 = new TreeNode("ddd");
        TreeNode t5 = new TreeNode("eee");
        TreeNode t6 = new TreeNode("fff");
        TreeNode t7 = new TreeNode("ggg");
        t1.left = t2;//左分支
        t1.right = t3;//右分支


        t2.parent = t1;//父节点
        t2.left = t4;//左分支
        t2.right = t5;//右分支


        t3.parent = t1;//父节点
        t3.left = t6;//左分支
        t3.right = t7;//右分支


        t4.parent = t2;//父节点
        t5.parent = t2;//父节点


        t6.parent = t3;//父节点
        t7.parent = t7;//父节点
    }
}
class TreeNode
{
    Object Data;//本节点信息
    TreeNode left;//左分支
    TreeNode right;//右分支
    TreeNode parent;//父节点


    public TreeNode()
    {
    }


    public TreeNode(Object data)
    {
        Data = data;
    }
}

结构图如图:

 

栈:(Stack)又称为堆栈或堆叠,是限制在表的一端进行插入和删除运算的线性表。

最先进入的数据被压入栈底,最后的数据在栈顶。每次删除(退栈),删除的总是当前栈中最后进入(进栈)的元素,而最先插入的数据在栈底,最后退栈。(后进先出,先进后出)

·属于抽象数据类型。

·可以使用数组或链表来构建

栈的模拟代码如下:

package 数据结构.栈;


import java.util.Arrays;


public class Test
{
    public static void main(String[] args)
    {
        Stack ss = new Stack(5);
        ss.push("abc");
        ss.push("def");
        ss.push("ghi");
        System.out.println(Arrays.toString(ss.values));
        ss.pop();
        System.out.println(Arrays.toString(ss.values));
    }
}
class Stack{
    Object[] values;//栈中的元素
    int size;//用来记录存储元素的个数


    public Stack(int length)
    {
        values = new Object[length];
    }
    //入栈
    public void push(Object ele)
    {
        if(size >= values.length)
        {
            throw new RuntimeException("栈空间已满");
        }
        values[size] = ele;
        size++;
    }
    //出栈
    public Object pop()
    {
        if(size <= 0)
        {
            throw new RuntimeException("栈空间已空");
        }
        Object o = values[size - 1];
        values[size - 1] = null;
        size--;
        return o;
    }
}

队列:(queue)

·属于抽象数据类型

·元素的添加获取满足“先进先出”。

队列的模拟代码如下:

package 数据结构.队列;


public class Test
{

}
class Queue
{
    Object[] values;
    int size;//记录村存储的数据的个数
    public Queue(int length)
    {
        values = new Object[length];
    }
    public void add(Object ele)//添加
    {
         if(size >= values.length)
         {
             throw new RuntimeException("队列已满");
         }
         values[size] = ele;
         size++;
    }
    public Object get()//获取
    {
        if(size <= 0)
        {
            throw new RuntimeException("队列已空");
        }
        Object o = values[0];
        //数据前移
        for (int i = 0; i < size - 1; i++)
        {
            values[i] = values[i + 1];
        }
        //最后一个元素置空
        values[size - 1] = null;
        return o;
    }
}

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

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

相关文章

泵类设备常见的5种故障及监测方法

在各种工业领域中&#xff0c;泵是一种关键设备&#xff0c;用于输送液体或气体。然而&#xff0c;泵类设备常常会面临各种故障&#xff0c;这可能导致生产停顿和生产效率下降。为了及时监测并解决这些故障&#xff0c;设备状态监测系统成为一种重要的工具。本文将介绍泵类设备…

CSDN专栏设置

文章目录 一、规则1.1、专栏数量与等级关联1.2、等级与积分关联1.3、积分1.3.1、积分获取1.3.2、积分被扣 二、配置2.1、入口2.2、新建2.2.1、一级专栏2.2.2、二级专栏 2.3、快捷编辑2.4、拖拽 一、规则 写了一阵子CSDN博客后&#xff0c;发现自己新增专栏的时候提示不能再新增…

kubeadm join 192.168.10.16:6443 --token xxx报错Failed to request cluster-info

1、node节点执行 kubeadm join 192.168.10.16:6443 --token hak4zi.hrib9uv4p62t1uok --discovery-token-ca-cert-hash sha256:4337638eef783ee6a66045ad699722079e071c2dfbaa21e37d3174f04d58ea97 --v2 报错 [discovery] Failed to request cluster-info, will try again: G…

华为云cce中环境变量的使用

如上图&#xff0c;cce中的环境变量可配置。 配置后的这些参数怎么用呢&#xff1f; 我们可以在docker打包前在springboot的配置文件中配置&#xff0c;cce在启动的时候会调用环境变量中的设置。 如上图&#xff0c;配置的东西以key值标记&#xff0c;冒号后面的是默认配置项…

编译器安全

在供应链安全中&#xff0c;大家一直关注采用SCA工具分析开源组件中的安全漏洞以及许可证的合规性。但是对于底层软件开发使用的编译器、链接器等安全却容易被忽视&#xff0c;其中有没有安全漏洞、有没有运行时缺陷、有没有被植入漏洞、木马等&#xff0c;似乎并没有引起多少人…

想面试前端工程师,必须掌握哪些知识和技能?【云驻共创】

在当今的数字化时代&#xff0c;前端工程师扮演着至关重要的角色。他们负责设计和开发用户界面&#xff0c;使得用户能够与应用程序或网站进行互动。为了找到最出色的前端工程师&#xff0c;你需要了解哪些技能和知识是必备的&#xff0c;同时也要掌握一些面试技巧和常见的面试…

上门维修安装派单系统小程序APP开发之会员级别设计深度解析

啄木鸟鲁班大师上门安装维修平台APP开发之VIP会员解析&#xff0c;在APP或者小程序里设置的会员叫VIP级别会员&#xff0c;系统一共分为4种会员&#xff0c;注册会员&#xff0c;正式会员&#xff0c;VIP金卡会员&#xff0c;VIP钻卡会员。注册用户是指注册了平台但是没有消费记…

【Windows 常用工具系列 11 -- win11怎么设置不睡眠熄屏 |win11设置永不睡眠的方法】

文章目录 win11 怎么设置不睡眠熄屏 使用笔记本电脑的时候&#xff0c;如果离开电脑时间稍微长一点就会发现息屏了&#xff0c;下面介绍 设置 Win11 永不睡眠息屏的方法&#xff0c;有需要的朋友们快来看看以下详细的教程。 win11 怎么设置不睡眠熄屏 在电脑桌面上&#xff0c…

说一下类的生命周期

&#x1f47d;System.out.println(“&#x1f44b;&#x1f3fc;嗨&#xff0c;大家好&#xff0c;我是代码不会敲的小符&#xff0c;双非大四&#xff0c;Java实习中…”); &#x1f4da;System.out.println(“&#x1f388;如果文章中有错误的地方&#xff0c;恳请大家指正&a…

同为科技(TOWE)桌面PDU插排:一款可以DIY定制的“超级插座”

当今社会&#xff0c;各种电子产品和家用电器已成为人们日常生活中不可或缺的一部分&#xff0c;在带给人们便利的同时&#xff0c;也使得电力使用变得更加频繁和重要。然而&#xff0c;当前市面上很多普通插座由于功能单一、材质粗劣、插口数量受限、充电速度过慢、插头间互相…

Vue 项目实战——如何在页面中展示 PDF 文件以及 PDFObject 插件实战

文章目录 &#x1f4cb;前言&#x1f3af;使用 HTML 标签&#x1f9e9; embed 标签&#x1f9e9; object标签&#x1f9e9; iframe标签&#x1f9e9;完整代码 &#x1f3af;使用 PDFObject 插件&#x1f9e9;为什么使用 PDFObject 插件&#xff08;AI翻译&#xff09;&#x1f…

Gitlab安装与操作

GitLab 是一个用于仓库管理系统的开源项目&#xff0c;使用Git作为代码管理工具&#xff0c;并在此基础上搭建起来的Web服务。 可通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能&#xff0c;能够浏览源代码&#xff0c;管理缺陷和注释。可以管理团队对仓库的…

c++|引用

目录 一、引用概念 二、引用特性 三、常引用 &#xff08;具有常属性的引用变量&#xff09; 四、使用场景 一、引用概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;他和他引用的变量共用同…

C++ 使用c++类模板实现动态数组-可实现自定义数据类型存储

.hpp文件 #include <iostream> #include <cstdlib> #include <cstring> using namespace std; template <class T> class arraylist { private:T* data ;//数组地址int size;//长度int count;//容量public:arraylist();~arraylist();void add(T t);T&…

革新突破!智能指标平台引领时代,国产大模型与企业级部署的完美结合

11月21日&#xff0c;跬智信息&#xff08;Kyligence&#xff09;圆满召开了线上数智论坛暨产品发布会&#xff0c;升级智能一站式指标平台 Kyligence Zen 及 AI 数智助理 Kyligence Copilot 的一系列企业级能力&#xff0c;包括正式支持智谱 AI、百川智能等在内的多款国产大模…

什么是数字化工厂?企业数字化转型有什么好处?

科技在发展&#xff0c;时代在进步&#xff0c;全球信息化、数字化的步伐越来越快&#xff0c;数字化转型是否成功也成为企业在未来发展中能否做大做强的关键因素。而数字化工厂就是制造业数字化发展的一个重要发展方向&#xff0c;那么究竟什么是数字化工厂呢&#xff1f;它和…

IDEA如何将本地项目推送到GitHub上?

大家好&#xff0c;我是G探险者。 IntelliJ IDEA 是一个强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它支持多种编程语言和工具。它也内置了对Git和GitHub的支持&#xff0c;让开发者可以轻松地将本地项目推送到GitHub上。以下是一个操作手册&#xff0c;描述了…

JSP:Tag文件的使用

需求&#xff1a;多个JSP页面可能需要使用一些相同的信息 例如:导航栏、标题等。 目标&#xff1a;提高这些相同信息的代码的复用性。 方法&#xff1a;将这些相同的元素形成一种特殊的文件&#xff0c;以便所有页面都可以使用&#xff0c;即&#xff1a;Tag文件 1、Tag对…

关于lenra你需要了解的

monorepo&#xff1a;项目代码管理方式&#xff0c;单个仓库中管理多个项目是一种设计思想 lenra&#xff1a;是一种工具&#xff0c;对于使用npm和git管理多软件包代码仓库的工作流程进行优化 使用这些工具的优点&#xff1a; 公共依赖只要安装一次&#xff0c;Monorepo 中…