数据库高级 I

news2024/11/20 13:27:34

数据库高级 I

双向链表

  • 什么是双向链表

    双向链表是一种数据结构,由若干个节点构成,其中每个节点均由三部分构成,分别是前驱节点,元素,后继节点.双向链表中的节点在内存中是游离状态存在的.
    

请添加图片描述

  • 双向链表的应用:LinkedList

    双向链表中的元素部分保存的都是对象,实际上保存的是元素对象的地址.
    
  • 对双向链表的操作

    • 添加元素

      add(E) -- 在链表尾部添加元素   
      	将元素封装到节点中,创建新节点,让新节点和前一个节点建立双向链表的关系.
      add(int index,E e) -- 在指定位置插入元素
      	其过程实际上就是断开链,重新构建链的过程
      
    • 删除元素

      remove(int index)-- 删除指定位置的元素
      	其过程实际上依然是断开链,重新构建链的过程
      
    • 查询元素

      get (int index) - E
      	查询方式:对半查找
      	若查找的位置小于链表长度的一半,则从头结点开始顺序查找;否则,从尾结点开始逆序查找,这样做可以提高查询效率.
      

      注意点:双向链表中没有下标,index表示的是节点从头结点开始的顺序位置.index并不是双向链表中的属性

    • 修改元素

      set(int index,E e) -- 将新元素替换指定位置的元素
      
    • 面试题相关:

      1. LinkedList在JDK1.8前后数据结构是不同的
      JDK1.8开始,LinkedList的数据结构为双向链表
      在JDK1.8之前,LinkedList的数据结构是双向循环链表.(头尾相接)
          
      双向循环链表的查找过程与双向链表相同,均为:
      	1. 判断查找元素位置与链表长度一半的关系:
      		小于,则从header开始顺序查找
      		否则,则从header开始逆序查找
      

请添加图片描述

    1. ArrayList和LinkedList的区别

      1. ArrayList底层是数组实现的,LinkedList底层是双向链表,二者的数据结构是不同的.
      2. 因为数据结构不同,所以最终的性能是不同的.
         查询元素:
      		ArrayList是根据下标查找元素,查询效率非常高,时间复杂度为O(1)
              LinkedList中若查找头部/尾部的元素,其查询效率还是比较高的,但是若查找偏中间位置的元素,其查询效率是比较低下的.
         增删元素:
      		ArrayList:若在尾部添加增删元素,此时性能可能会很高,在头部和中间位置进行增删操作,其效率都不是很高.
              LinedList:若在头尾部分增删元素,此时性能很高,但是若在偏中间位置进行增删元素,此时性能不高的(因为增删,会先查询指定位置的节点,查询效率是低下的)
                      
         整体而言:
      		ArrayList查询性能是高于LinkedList,但是若LinkedList进行头尾查询,此时效率也是非常高的.
              若进行的是偏头部和尾部的增删操作,选择LinkedList;而若对其他位置进行增删,此时ArrayListLinkedList的效率是差不多的.
                      
             整体来看,ArrayList查询方面性能更好,增删方面,除了头尾增删,其他增删和LinkedList差不多,所以经常使用ArrayList.
                      
      面试标准回答:ArrayList查询性能更高,LinkedList进行头尾增删,性能很高,除此之外,其他增删,ArrayListLinkedList差不多.
      

递归 – recursion

  • 定义

    递归是一种思想,应用在编程中体现为方法调用方法本身.
    
  • 案例: 实现求某个数的阶乘

    1! = 1           
    2! = 2*1         2*1!
    3! = 3*2*1       3*2!
    4! = 4*3*2*1     4*3!
    5! = 5*4*3*2*1   5*4!
        
        
    //f方法用于求出某个数的阶乘   
    long f(int n){
       if(n==1)
           return 1;
       return n*f(n-1);
    }
    

    请添加图片描述

  • 递归经典案例:

    斐波那契数列(Fibonacci)是这样一组数列:  1 1 2 3 5 8 13 21 34 55.....  第一位第二位为1,从第三位开始,每一位的值等于前两位之和.
    
    1. 求出斐波那契数列中第20个位置的值是多少

      public  int  f(int pos){
          if(pos==1 || pos==2)
              return 1;
          return f(pos-1)+f(pos-2);
      }
      
    2. 将斐波那契数列前20个数字打印输出

      for (int i=1;i<=20;i++){
          int result = f(i);
          System.out.print(result+" ");
      }
      
  • 递归注意点:

    1. 递归必须有出口,否则会栈内存溢出(SOF)--StackOverflowError
    2. 递归是有深度,若深度太深,可能会造成SOF
    
    栈内存回顾: 用法: 当调用某个方法时,会在栈中为这个方法分配属于这个方法的栈帧区域,某个方法的栈帧中保存这个方法中的所有局部变量
    
  • 面试题: SOF和OOM

    SOF: statckOverFlowError   -- 栈内存溢出
    OOM: OutOfMemoryError -- 堆内存溢出
    内存溢出:剩余内存不足以分配给请求的资源,此时会出现内存溢出.
        原因:
    		1. 创建大对象
    		2. 内存泄漏的不断累积,内存泄漏一直累积到一定程度,则会出现堆内存溢出.
                
    内存泄漏:分配出去的内存回收不回来,此时这个现象就叫做内存泄漏
                
    内存泄漏和内存溢出的区别
    	内存溢出:剩余内存不足以分配给请求的资源,这种现象叫做内存溢出.
        内存泄漏:分配出去的内存回收不回来,这个现象叫做内存泄漏
        
        关系:  内存泄漏累积到一定程序才会造成内存溢出,并不是内存泄漏一旦出现,则立即出现内存溢出,
        出现内存溢出并不一定是由于内存泄漏造成的,还可能是因为创建了大对象造成的。
            
        内存泄漏,则一定会出现内存溢出?   错误
        内存溢出一定是由于内存泄漏引起的?   错误
    

树 - tree

  • 树是数据结构,由若干个节点构成,其中有且仅有一个根节点.

  • 树的术语:

    高度: 树的层次
    根节点: 有且仅有一个
    度: 树中节点的最大子节点数
    叶子节点: 度为0的节点
    

    请添加图片描述

二叉树:

  • 度为2的树,则为二叉树

二叉排序树

  • 定义

    二叉排序树(Binary Sort Tree),又称二叉查找树(Binary Search Tree),亦称二叉搜索树。是数据结构中的一类。在一般情况下,查询效率比链表结构要高。
    
  • 特点

    1. 元素不能重复
    2. 左子树中的节点均小于根节点
    3. 右子树中的节点均大于根节点
    

    请添加图片描述

  • 二叉排序树的查询效率高于单向链表

    单向链表中,查询元素,最差的情况要查询n次;而在二叉排序树中,每次比较,均可以排除将近一半的数据,所以查询次数会大大减少.查询效率高于单向链表
    
  • 二叉排序树中的元素可以是其他引用类型,但是要求该引用类型的对象之间是可比较大小的,如何保证对象之间能比大小?

    实现Comparable接口,在类中定义比较规则,则对象之间是可比较大小的.
    

我是将军;我一直都在,。!

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

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

相关文章

Tomcat 源码解析一请求处理的整体过程-黄泉天怒(下)

上一篇博客 Tomcat 源码解析一请求处理的整体过程-黄泉天怒(上) NonLoginAuthenticator NonLoginAuthenticator并没有实现invoke()方法&#xff0c;而是由父类AuthenticatorBase实现了invoke()方法&#xff0c;AuthenticatorBase类关系如下。   先弄清楚NonLoginAuthentica…

07.URL调度器工作原理

1.工作原理 django通过urlconf来映射视图函数&#xff0c;只区分路径&#xff0c;不区分http方法 Django确定要使用的根URLconf模块&#xff0c;一般实在settings中的ROOT_URLCONF设置的值&#xff0c;但是如果传入HttpRequest对象具有一个urlconf属性&#xff08;由中间件设置…

直播预告|OceanBase 社区版 4.0 全解析

小就是大&#xff0c;OceanBase 社区版 4.0 | 单机到分布式一体化与最佳实践 随着云原生时代的到来&#xff0c;越来越多的业务系统会采用云原生架构。云原生数据库通过资源解耦和资源池化等技术支撑了不同业务领域的场景需求。 2022 年 11 月 3 日&#xff0c;OceanBase 社区版…

Linux结构目录说明以及相关作用【重点】

目录目录结构目录结构介绍&#xff1a;/bin [重点] (/usr/bin 、 /usr/local/bin)/home/root/sbin/lib/lost found/etc/usr/boot/dev/media/mnt/opt/usr/local/var目录结构 1&#xff1a;图解目录结构 2&#xff1a;用命令行看目录结构&#xff08;里面自己装了一些东西&…

1024程序员节过后,我才知道JVM有多重要

为什么要学习JVM? 和大部分程序员一样&#xff0c;我最初接触 Java 虚拟机只是因为面试官会问Java虚拟机的相关问题&#xff0c;所以不得不看&#xff0c;而且刷了很多面试题&#xff1b;那段时间刷面试题刷的心烦甚至会觉得&#xff0c;我面试的岗位平时也用不上Java虚拟机&…

奉加微蓝牙芯片PHY6222,支持mesh,SRAM、可选128K-8M

奉加微蓝牙芯片PHY6222&#xff0c;支持mesh&#xff0c;SRAM、可选128K-8M ​SIG mesh和ZigBee两种2.4G的无线mesh&#xff0c;有Nordic的NRF52840&#xff1b;泰凌微的TLSR825X、TLSR9X&#xff1b;还有奉加微的PHY62xx系列是一款支持BLE 5.2功能和IEEE 802.15.4&#xff08;…

【数据结构基础】时间复杂度和空间复杂度

&#x1f648;个人主页&#xff1a;阿伟t &#x1f449;系列专栏&#xff1a;【C语言–大佬之路】 &#x1f388;今日心语&#xff1a;你所看到的惊艳&#xff0c;都曾被平庸所历练。 数据结构指的是“一组数据的存储结构”&#xff0c;算法指的是“操作数据的一组方法”。 数…

Spring Boot快速入门

目录 1、Spring Boot概述 1.1、什么是Spring Boot 1.2、Spring Boot的特点 2、Spring Boot快速入门 2.1、起步依赖 2.2、创建启动类 2.3、测试启动类 2.4、自定义banner 2.5、自动配置原理 2.6、启动类注解 3、Spring Boot整合SpringMVC 3.1、Controller类 3.2、…

效率为王,居家办公必备的5款小工具

疫情反反复复&#xff0c;好多小伙伴依然处在居家办公的境地中&#xff0c;所以像小编一样早早的干完活躺床上是非常有必要的。 1.极速复制粘贴工具——TeraCopy TeraCopy是一款老牌免费的 Windows 文件复制/移动辅助加速工具软件&#xff0c;复制文件时若是遇上数据有问题也…

《FFmpeg Basics》中文版-03-比特率/帧率/文件大小

正文 比特率和帧速率是视频的基本特征&#xff0c;它们的正确设置对整体视频质量非常重要。 如果我们知道所有包含的媒体流的比特率和持续时间&#xff0c;我们可以计算输出文件的最终大小。 由于在使用FFmpeg工具时对帧速率和比特率的理解很重要&#xff0c;因此包含每个术语…

文件存储解决方案-云存储阿里 OSS

文件存储解决方案-云存储阿里 OSS 1.文件存储&#xff08;上传&#xff09;解决方案讨论 1.图解 文件存储解决方案-云存储阿里 OSS 解读上图 普通上传并不是分布式&#xff0c;也不是集群&#xff0c;可用性不高普通上传的分布式情况&#xff0c;使用了集群&#xff0c;但是…

数据结构每日亿题(七)

文章目录一题目二.思路2.1链表2.2数组三.代码一题目 原题传送门&#xff1a;力扣 题目&#xff1a; 题目的意思是让你写一个数据结构&#xff0c;这个结构的特点和队列一样先进先出&#xff0c;然后完成&#xff1a;判断是否为空&#xff0c;判断是否为满&#xff0c;添加一个…

实验29:循迹传感器实验

今天讲一个基本实验 循迹实验 循迹传感器的原理是: CTRT5000传感器的红外发射管不断发射红外光。由于黑色吸收光线,当红外发射管照射黑色表面时,反射光较少,接收管接收的红外线较少。这表明黑色吸收光线的强度大,那么比较器输出高电平,指示灯熄灭。同样,当它在白色表面…

MCE虚拟筛选化合物库

Discovery Diversity Sets 新颖的化合物库&#xff01; 药物筛选是发现药物先导物的重要途径&#xff0c;好的化合物库则是药物筛选的必备武器。MCE 拥有丰富的数据库资源&#xff0c;助力您的药物筛选研究&#xff01;药物筛选研究与化合物新颖性密切相关。Discovery Divers…

单目标应用:求解旅行商问题(TSP)的猎豹优化算法(The Cheetah Optimizer,CO)提供MATLAB代码

一、猎豹优化算法 猎豹优化算法&#xff08;The Cheetah Optimizer&#xff0c;CO&#xff09;由MohammadAminAkbari等人于2022年提出&#xff0c;该算法性能高效&#xff0c;思路新颖。 参考文献&#xff1a; Akbari, M.A., Zare, M., Azizipanah-abarghooee, R. et al. The…

Linux实战案例——使用LNMP+WordPress搭建个人博客网站

一、案例目标 了解 LNMP 环境的组成。 了解 LNMP 环境的部署与安装。 了解 WordPress 应用的部署与使用二、环境介绍 1.LNMP LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux&#xff0c;N指Nginx&#xff0c;M一般指MySQL&#xff0c;也…

技术分享 | TiUP工具 - TiDB集群滚动升级核心流程解析

作者&#xff1a;贲绍华 爱可生研发中心工程师&#xff0c;负责项目的需求与维护工作。其他身份&#xff1a;柯基铲屎官。 本文来源&#xff1a;原创投稿 *爱可生开源社区出品&#xff0c;原创内容未经授权不得随意使用&#xff0c;转载请联系小编并注明来源。 引言&#xff1a…

运维工程师怎么找兼职?什么样的兼职合适?

运维老哥们应该都知道&#xff0c;这个岗位其实是个很宽泛的定义&#xff0c;不同公司对运维的要求也不一样。有些公司所谓运维就是桌面helpdesk ,有些公司就是网管。基本上从修电脑到会写点脚本做自动化&#xff0c;各个层次的都有。现状就是&#xff0c;有少数公司或者大厂的…

基于Django的图书交易系统

摘 要 随着信息化时代的到来&#xff0c;管理系统都趋向于智能化、系统化&#xff0c;图书交易系统也不例外&#xff0c;但目前国内的有些公司仍然都使用人工管理&#xff0c;图书销量越来越大&#xff0c;同时信息量也越来越庞大&#xff0c;人工管理显然已无法应对时代的变化…

第五课 算术运算

一、加法与减法 经过上次课的学习&#xff0c;我们已经学会了该如何在控制台中输出我们想要的内容了&#xff0c;但是计算机计算机&#xff0c;最早其实是用来进行计算的&#xff0c;Python能做这事吗&#xff0c;我们来试试。 看到这结果&#xff0c;估计很多同学就该说了&…