首页 > 编程语言 >重学java 58.红黑树相关集合

重学java 58.红黑树相关集合

时间:2024-06-07 22:31:22浏览次数:18  
标签:重学 java 58 age Person String new public name

现在还来得及

                       —— 24.6.3

一、TreeSet

1.概述:

        Treeset是set的实现类

2.特点:

        a.对元素进行排序
        b.无索引
        c.不能存null
        d.线程不安全
        e.元素唯一

3.数据结构:

        红黑树

4.构造

        Treeset() —> 构造一个新的空 set,该 set 根据其元素的自然顺序进行排序 -> ASCII
        Treeset(comparator<? super E> comparator) —> 构造一个新的空 Treeset,它根据指定比较器进行排序

public class Person {
    private String name;
    private Integer age;

    public Person() {
    }

    public Person(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
import java.util.TreeSet;

public class Demo252TreeSet01 {
    public static void main(String[] args) {
        TreeSet<String> set1 = new TreeSet<>();
        set1.add("c.白毛浮绿水");
        set1.add("a.鹅鹅鹅");
        set1.add("b.曲项向天歌");
        set1.add("d.红掌拨清波");
        System.out.println(set1);   // [a.鹅鹅鹅, b.曲项向天歌, c.白毛浮绿水, d.红掌拨清波]
    }
}
import java.util.Comparator;
import java.util.TreeSet;

public class Demo253TreeSet02 {
    public static void main(String[] args) {
        TreeSet<Person> treeSet = new TreeSet<>(new Comparator<Person>() {

            @Override
            public int compare(Person o1, Person o2) {
                return o1.getAge()-o2.getAge();
            }
        });
        treeSet.add(new Person("小明",17));
        treeSet.add(new Person("小红",18));
        treeSet.add(new Person("小刚",16));
        System.out.println(treeSet);    // [Person{name='小刚', age=16}, Person{name='小明', age=17}, Person{name='小红', age=18}]
    }
}

二、TreeMap

1.概述:

        Treeset是set的实现类

2.特点:

        a.对元素进行排序
        b.无索引
        c.key唯一
        d.线程不安全
        e.不能存null

3.数据结构:

        红黑树

4.构造:

        TreeMap() —> 使用键的自然顺序构造一个新的、空的树映射 —> ASCII
        TreeMap(Comparator<?super E> comparator) —> 构造一个新的、空的树映射,该映射根据给定比较器进行排序

import java.util.Comparator;
import java.util.TreeMap;

public class Demo254TreeMap01 {
    public static void main(String[] args) {
        TreeMap<String, String> map = new TreeMap<>();
        map.put("a", "苦难是生活的花开");
        map.put("c","一切都会好的");
        map.put("b","我一直相信");
        System.out.println(map);

        TreeMap<Person, String> map2 = new TreeMap<>(new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                return o1.getAge()-o2.getAge();
            }
        });

        map2.put(new Person("小明",17),"北京");
        map2.put(new Person("小红",18),"上海");
        map2.put(new Person("小刚",16),"江苏");
        System.out.println(map2);
    }
}

标签:重学,java,58,age,Person,String,new,public,name
From: https://blog.csdn.net/m0_73983707/article/details/139422497

相关文章

  • Java中运算与规则相关细节
    每日一句对待已然的事实,最快速度通关方法就是:觉察自己的心理和情绪,看见和观照,不断深呼吸,直到放下抗拒放弃排斥,直到接受事实全然接纳,全然巨服。对事实说:“是的”。然后看看,在接纳的基础上我还能做些什么。学习内容模运算a%b=a-a/b*b;符号取决于a++–自增和自......
  • Java 八股文-基础篇
    Java基础一、Java概述1.什么是Java?Java是一门面向对象的编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的优秀代表,极好地实现了面向对象理论,允许程......
  • Java为什么会成为现在主流的编程语言
    JDK动态代理 是Java标准库提供的一种实现动态代理的方式。具体来说,它允许在运行时动态地创建对象,并将方法调用重定向到代理对象中的处理程序(InvocationHandler)。其核心原理是通过反射机制,在运行时生成一个实现了被代理对象接口的匿名类,并通过该匿名类来创建代理对象。这个匿名......
  • Java 的动态代理是基于什么原理?
    Java的动态代理是基于以下原理实现的:代理模式:代理模式是一种设计模式,通过创建一个代理对象来控制对真实对象的访问。代理对象可以在调用真实对象之前或之后增加额外的逻辑,比如权限验证、记录日志等。代理模式的主要目的是在不修改原有代码的基础上,扩展对象的行为。动......
  • Java基础——数组应用之StringBuilder类和StringBuffer类
    系列文章目录文章目录系列文章目录前言一、StringBuffer类二、StringBuffer概述三、StringBuffer方法四、StringBuilder类五、String、StringBuffer、StringBuilder的区别前言前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点......
  • JavaScript中的async/await
    async/await是什么?async是一个修饰符,async定义的函数会默认的返回一个Promise对象resolve的值,因此对async函数可以直接进行then操作,返回的值即为then方法的传入函数。await也是一个修饰符,await关键字只能放在async函数内部,await关键字的作用就是获取Promise中返回......
  • 【Java笔记】第十章:接口
    一、理解1.接口:是一种标准,接口的实现者和使用者都必须遵循的约定2.语法特点:(1)接口的关键字:interface(2)接口的语法:   interface接口名{}(3)接口不能创建对象,可以声明引用(4)接口中的属性都是公开的、静态的、常量(默认被public、static、final修饰)(......
  • 在Java、Java Web中放置图片、视频、音频、图像文件的方法
    在Java软件中放置图片,通常涉及将图片文件(如JPEG、PNG等)作为资源包含在我们的项目中,并在代码中通过适当的方式引用这些资源。这可以通过多种方式实现,但最常见的是在Java桌面应用(如Swing或JavaFX)或Web应用(如Servlet/JSP)中。1.如何在Java中如何放置图片以下是一个在JavaSwing桌......
  • java mqtt自动重连注意点
    1、在使用Java的 org.eclipse.paho.client.mqttv3 MQTT客户端库时,options.setAutomaticReconnect(false) 的设置是用来指定在连接丢失后,客户端是否应该自动尝试重新连接。将其设置为 false 意味着如果连接丢失,客户端不会自动尝试重新连接。然而,即使设置了自动重连为 fa......
  • Java中实现图片和Base64的互相转化
    前言公司项目中用到了实名认证此,采用的第三方平台。后端中用到的单项功能为身份证信息人像对比功能,在写demo的过程中发现,它们所要求的图片信息为base64编码格式。一、代码packagecom.bajiao.wyq.tools.chuanglan;importjava.awt.image.BufferedImage;importjava.io.ByteArray......