【系统学习】2-Java进阶知识总结-3-集合-1-补充【泛型、树、数据结构】

文章目录

  • 泛型
    • 什么是泛型?
    • 常见的泛型标识符
    • 泛型类
    • 泛型方法
    • 泛型接口
    • 通配符
    • 树的基本概念
    • 什么是二叉树?
    • 二叉树--普通二叉树
    • 二叉树--二叉查找树
      • 定义规则
      • 优缺点
    • 二叉树--平衡二叉树
      • 定义规则
      • 旋转机制
    • 二叉树--红黑树
      • 定义规则
      • 红黑规则
  • 常见数据结构
    • 总体特点
    • 结构图

泛型

什么是泛型?

含义的理解还不够深入

泛型:指广泛的数据类型

本质:是参数化类型,即操作的数据类型被指定为一个参数。

用途:泛型可以用在类、接口、方法中,分别称为:泛型类、泛型接口、泛型方法。

版本信息:于JDK5版本引入

常见的泛型标识符

ETKVN
ElementTypeKeyValueNumber通配符
集合元素表示任意Java类的类型键类型值类型数值类型表示任意类型
  • 通配符?:可以理解为所有类的父类

泛型类

示例

package com.itheima.day10.generics;

import java.util.ArrayList;

public class GenericsDemo2 {
    public static void main(String[] args) {
        Student<Integer> stu = new Student<>(); // 正确
        Student<int> stu = new Student<>();   // 错误,泛型类只能是引用数据类型
    }
}

class Student<E> {
    private E e;

    public E getE() {
        return e;
    }

    public void setE(E e) {
        this.e = e;
    }
}

特点

  • 泛型类只能写引用数据类型!!
  • 泛型类,只有创建对象的时候,才能确定泛型具体的类型

泛型方法

非静态的泛型方法

特点:根据类的泛型去匹配:类的泛型传入什么类型,方法就传入什么类型

泛型类型确定的时机:类创建实例对象的时候

举例:上述的get()set()方法

静态的泛型方法

特点:必须声明出自己独立的泛型

  • 因为:静态方法随着类的加载而加载,此时类还没创建,就没有具体类型,静态方法就会有问题,所以要声明自己独立的泛型

泛型类型确定的时机:该方法被调用的时候

举例:

package com.itheima.day10.generics;

public class GenericsDemo3 {
    public static void main(String[] args) {

        String[] arr1 = {"张三", "李四", "王五"};
        Integer[] arr2 = {11, 22, 33};
        Double[] arr3 = {11.1, 22.2, 33.3};

        printArray(arr1);
        printArray(arr2);
        printArray(arr3);
    }

    public static <T> void printArray(T[] arr) {
        System.out.print("[");
        for (int i = 0; i < arr.length - 1; i++) {
            System.out.print(arr[i] + ", ");
        }
        System.out.println(arr[arr.length - 1] + "]");
    }
}

泛型接口

特点:类实现接口的时候,可以有两种选择:确定泛型类型;保留泛型类型

interface Inter<E> {
    void show(E e);
}

示例1:类实现接口的时候,直接确定类型(就变成普通类了)

class InterAImpl implements Inter<String> {

    @Override
    public void show(String s) {
    }
}

示例2:延续接口的泛型,等创建对象的时候确定(变成泛型类)

class InterBImpl<E> implements Inter<E>{

    @Override
    public void show(E e) {
    }
}

通配符

这部分的概念也有点难理解

通配符的类别

?? extends xxx? super xxx
无边际通配符固定上边界统配符固定下边界统配符
<?><? extends E><? super E>
泛型可以接受未知类型的数据(任意类型)限制泛型可以接受的类型为:xxx及xxx的子类、实现接口xxx的类限制泛型 可以接受的类型为:xxx及xxx的父类

示例

// 父类
@Data
abstract class Employee {
    private String name;
    private double salary;

    public abstract void work();
}
// 继承的子类
class Coder extends Employee {
    @Override
    public void work() {
        System.out.println("程序员写代码...");
    }
}

class Manager extends Employee {
    @Override
    public void work() {
        System.out.println("项目经理分配任务...");
    }
}
// 调用
public class GenericsDemo5 {
    public static void main(String[] args) {

        ArrayList<Coder> list1 = new ArrayList<>();
        list1.add(new Coder());

        ArrayList<Manager> list2 = new ArrayList<>();
        list2.add(new Manager());

        method(list1); // 固定上界统配符
        method(list2); // 固定下界统配符
    }

    public static void method(ArrayList<? extends Employee> list){
        for (Employee o : list) {
            o.work();
        }
    }
    
    public static void method1(ArrayList<? super Employee> list){
        for (Object A : list) {
            Employee o = (Employee)A;
            o.work();
        }
    }    
}

树的基本概念

image-20231017154352376

概念理解
节点(结点、Node)上边的每一个圈圈都是一个节点【节点内部存储有:父节点地址、节点数据值、左子节点地址、右子节点地址】
每一个节点的子节点数量【在二叉数中,任意节点的度<=2】
树高整棵树的层数【上边数的树高=4】
根节点最顶层的节点【节点值为22的这个节点,其左子节点为18,右子节点为26,没有父节点】
左子节点【22的左子节点是18】
右子节点【22的右子节点是26】
根节点的左子树【18节点及其所有子节点】
根节点的右子树【26节点及其所有子节点】

什么是二叉树?

二叉树是每个节点最多有两个子树的树结构。

下边相关二叉树,先学习基本特点和优缺点,后续做题的时候,再学习相关原理、方法,写出代码

二叉树–普通二叉树

仅满足二叉树的规则,没有多余的特点

image-20231017155918842

二叉树–二叉查找树

二叉排序树,又称二叉查找树,亦称二叉搜索树

image-20231017155958621

定义规则

  • 若左子树不为空,则左子树上所有节点的值均小于或等于它的根节点的值
  • 若右子树不为空,则右子树上所有节点的值均大于或等于它的根节点的值
  • 任意节点的左右子树,也都是二叉查找树

优缺点

  • 优点:常规情况下,元素查找速度快,每一次查找,筛选掉剩余元素的一半

  • 不足:特殊二叉查找树(所有节点仅有右节点或仅有左节点),每次查找只能过滤掉一个元素,查找速度变得跟数组一样

二叉树–平衡二叉树

image-20240229202425934

定义规则

1、平衡二叉树由若干个节点组成

2、如果一颗二叉树不为空,那么至少拥有一个根节点,且根节点没有父节点

3、每个子节点都符合如下规范:

  • 节点的数值限制:没有键值相等的节点

  • 节点的子节点数量限制:每个节点可以拥有最多两个子节点

  • 节点的左子树数值限制:若任意节点的左子树不空,则左子树上所有的节点值均小于该节点的值

  • 节点的右子树数值限制:若任意节点的右子树不空,则右子树上所有节点的值均大于该节点的值

  • 节点的左、右子树高度限制:节点左树和右树的高度差的绝对值小于等于1

旋转机制

挺巧妙地,用到了再说

二叉树–红黑树

定义规则

用到再说

红黑规则

用到再说

常见数据结构

总体特点

数据结构结构操作特点补充
一端开口(栈顶)
一端封闭(栈底)
从栈顶到栈底:进栈/压栈
从栈底到栈顶:出栈/弹栈
后进先出,先进后出
队列一端开口(后端)
一端开口(前端)
入队列(后端)、出队列(前端)先进先出,后进后出
数组起始地址值、索引根据地址值和索引定位数据查询速度快(且一致):索引+地址值定位;
增、删效率低:增删过程大概率伴随大量数据移动
链表基本组成:节点
本身地址、数据、下一个节点的地址
查询慢:查询任何数据都要从头开始查
增删相对快:查到对应元素,更改节点存储内容即可,不需要多余的移动
存储内存不连续
双向链表基本组成:节点
前一个节点地址、数据、下一个节点的地址
同【链表】存储内存不连续
见【补充知识-树】

结构图

image-20231018152435202

队列

image-20231018152516475

链表(单向链表和双向链表)

节点结构

image-20231017092555108

单项链表和双向链表

image-20231017092826875

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AI-数学-高中-31-统计-总体方差与样本方差(新教材内容)

原作者视频(P158)&#xff1a;【统计】【一数辞典】5方差知识补充&#xff08;中档&#xff09;&#xff08;新教材内容&#xff09;_哔哩哔哩_bilibili 方差研究的实际意义&#xff1a;方差是充分反映一组数据内波动大小程度的代表性描述数值。若一组数据内&#xff0c;方差越…

谷歌seo外链怎么发?

谷歌SEO外链建设&#xff0c;说白了&#xff0c;就是让别的网站放一条或几条链接指向你的网站&#xff0c;这事听着简单&#xff0c;但你凭什么在别人的地盘放自己网站的链接&#xff0c;就算真的能放自己网站的链接&#xff0c;你又是否能保证你发的内容跟自己网站相关&#x…

AI论文速读 | 【综述】城市计算中跨域数据融合的深度学习:分类、进展和展望

题目&#xff1a;Deep Learning for Cross-Domain Data Fusion in Urban Computing: Taxonomy, Advances, and Outlook 作者&#xff1a;Xingchen Zou, Yibo Yan, Xixuan Hao, Yuehong Hu, Haomin Wen&#xff08;温皓珉&#xff09;, Erdong Liu, Junbo Zhang&#xff08;张钧…

Java适配器设计模式

Java适配器设计模式这一节后面的内容

面向对象中不可变性

软件设计中的不可变性是一个非常重要的概念&#xff0c;它可以在多个方面提高代码的可靠性、可维护性和安全性。 从开发者角度&#xff08;代码提供者&#xff09;&#xff1a; 在软件开发过程中&#xff0c;当某个对象的属性是不可变的时候&#xff0c;这意味着这些属性的值…

用java实现A*寻路算法

前言&#xff1a; 最近的开发中遇到了寻路这个知识点&#xff0c;然后去了解了一下最常见的A算法&#xff0c;本会会结合我的理解&#xff0c;用最通俗易懂的话语讲解A算法的原理&#xff0c;下面会给出代码示例。 说到寻路算法&#xff0c;就涉及到了图的遍历&#xff0c;然…

开年采购云服务器,怎么买最划算?看这篇!

在2024年开年之际&#xff0c;对于许多企业和个人而言&#xff0c;采购云服务器已成为一项重要的决策。云服务器以其灵活性、可扩展性和高可用性等特点&#xff0c;吸引了越来越多的用户。然而&#xff0c;市场上的云服务器提供商众多&#xff0c;如何选择一家值得入手的服务商…

Domain Driven Design (DDD)

Domain Driven Design (DDD领域驱动设计)主要是业务分类例如&#xff08;订单、合同、生产、检测、物流、运输等&#xff09;&#xff0c;独立单元相互不干扰&#xff0c;仅暴露接口的模型。核心在Domain&#xff0c;所有业务模块放这边&#xff0c;当然我们做的时候微服务是一…

如何对接1688平台官方开发平台的商品发布/商品过期处理/商品订单接口?

custom-自定义API操作 API测试 注册开通 1688.custom 1688平台官方开放接口 公共参数 名称类型必须描述keyString是调用key&#xff08;必须以GET方式拼接在URL中&#xff09;secretString是调用密钥api_nameString是API接口名称&#xff08;包括在请求地址中&#xff09;[…

windows部署ruoyi-vue-pro

前提 安装java 安装maven 安装redis mysql 源代码下载 后端 ruoyi-vue-pro 前端 yudao-ui-admin-vue3 后端项目 配置maven 导入数据 CREATE DATABASE ruoyi_vue_pro;修改mysql连接配置 修改redis 打包项目 mvn clean install package -Dmaven.test.skiptrue启动YudaoSe…

TC397 Tasking CMake Gitlab CI CD 环境配置

文章目录 Aurix Development Studio 新建工程与配置Tasking 环境配置CMake 集成Win CMake MinGW 安装Tasking Toolchain 工具链CMakeLists.txtPowershell 脚本 Gitlab CI CDGithub Link 本篇先演示了ADS新建激活编译工程, 讲述了浮点模型, 链接脚本文件, 静态库集成等的设置, 接…

python并发编程:IO模型

一 IO模型 二 network IO 再说一下IO发生时涉及的对象和步骤。对于一个network IO \(这里我们以read举例\)&#xff0c;它会涉及到两个系统对象&#xff0c;一个是调用这个IO的process \(or thread\)&#xff0c;另一个就是系统内核\(kernel\)。当一个read操作发生时&#xff…

C语言学习--摩尔投票算法

目录 1.引入 2.摩尔投票算法 3.具体步骤 3.1抵消阶段 3.2检验过程 4.代码实现 5.总结 1.引入 今天做题看到一个解题思路真的看不懂&#xff0c;一艘才知道是这个算法。 int majorityElement(int* nums, int numsSize) { int notenums[0]; int count1; for(int i1;i<n…

day7-网络编程

1>基于UDP的网络聊天室 Ser.c #include <myhead.h> #define SER_IP "10.211.55.9" // 服务器IP #define SER_PORT 9999struct user {char usrName[20];struct sockaddr_in cin; }; int main(int argc, char const *argv[]) {// 1.创建用于监听的套接字int…

coqui-ai/TTS 案例model文件

GitHub - coqui-ai/TTS: &#x1f438;&#x1f4ac; - a deep learning toolkit for Text-to-Speech, battle-tested in research and production Coqui AI的TTS是一款开源深度学习文本转语音工具&#xff0c;以高质量、多语言合成著称。它提供超过1100种语言的预训练模型库&…

Elemenu中el-table中使用el-popover选中关闭无效解决办法

主要是技术太菜,没找到原因,一点点才找到这个办法解决 因为在el-table-column里,因为是多行,使用trigger"manual" 时,用v-model"visible"来控制时,控件找不到这个值,才换成trigger"click" 先找到弹出关闭事件,再找元素的属性 右键>审核元素…

哪款洗地机值得买?希亦、追觅、米博、美的谁才是行业标杆?

在家庭清洁中&#xff0c;最让我们苦恼的便是厨房垃圾了&#xff0c;油渍跟食物残渣&#xff0c;用扫把扫了后&#xff0c;要反反复复的湿拖五六次&#xff0c;期间不停的手洗拖把&#xff0c;这套流程下来&#xff0c;往往容易腰酸背痛&#xff0c;手指皱巴巴的&#xff0c;这…

Java项目:40 springboot月度员工绩效考核管理系统009

作者主页&#xff1a;源码空间codegym 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 本系统的功能分为管理员和员工两个角色 管理员的功能有&#xff1a; &#xff08;1&#xff09;个人中心管理功能&#xff0c;添加管理员账号…

【BUG修复日志】Anaconda + VSCode 编码错误

【BUG修复日志】Anaconda VSCode 编码错误 平台: Windows11家庭版 (v22621.3155) 软件: Visual Studio Code (v1.87.0) 插件: Python (v2024.2.1) 版本: Conda (v24.1.2)问题描述 VSCode 在安装 Python 插件的情况下自动提示配置 Conda 环境&#xff0c;但是在自动配置完成后…

SpringMVC实用技术

1.校验框架 1.表单校验框架入门 表单校验的重要性 数据可以随意输入&#xff0c;导致错误的结果。表单校验保障了数据有效性、安全性 表单校验分类 校验位置&#xff1a; 客户端校验 服务端校验 校验内容与对应方式&#xff1a; 格式校验 客户端&#xff1a;使用Js技术…