Java语言程序设计——篇十一(3)

在这里插入图片描述
在这里插入图片描述

🌿🌿🌿跟随博主脚步,从这里开始→博主主页🌿🌿🌿

  • 欢迎大家:这里是我的学习笔记、总结知识的地方,喜欢的话请三连,有问题可以私信🌳🌳🌳
    您的点赞👍、关注➕、收藏⭐️、评论📝、私信📧是我最大的支持与鼓舞!!!🌻🌻🌻

集合——Set

Set接口及实现类

  • Set接口是Collection的子接口,其中不允许有重复的元素。
  • Set接口没有定义新的方法,只包含从Collection接口继承的方法。
  • Set接口的常用实现类有:HashSet类、TreeSet类。

在这里插入图片描述

HashSet类

  • HashSet类用散列方法存储元素,具有最好的存取性能,但元素没有顺序。
  • HashSet类的构造方法有:

HashSet(): 初始容量是16,默认装填因子是0.75。
HashSet(Collection c)
HashSet(int initialCapacity)
HashSet(int initialCapacity, float loadFactor)

实战演练

例:HashSetDemo.java

```java
import java.util.*;

public class HashSetDemo {
     public static void main(String[] args) {
Set words = new HashSet<>();
words.add("one");
words.add("two");
words.add("three");
words.add("one"); //不能将重复元素添加到集合中
for(String s:words)
                System.out.print(s+" ");
      }
}

```

在这里插入图片描述

用Set对象实现集合操作

  • 使用Set对象的批量操作方法,可以实现标准集合代数运算。
  • 假设s1和s2是Set对象,下面的操作可实现相关的集合运算。

s1.addAll(s2):实现集合s1与s2的并运算。
s1.retainAll(s2):实现集合s1与s2的交运算。
s1.removeAll(s2):实现集合s1与s2的差运算。
s1.containAll(s2):如果s2是s1的子集,该方法返回true。

TreeSet类

  • TreeSet实现一种树集合, 它使用红-黑树算法为元素排序,因此集合中的元素是有序存放的。
  • 添加到TreeSet中的元素必须是可比较的,即元素的类必须实现Comparable接口。
  • 构造方法如下:

TreeSet()
TreeSet(Collection c)
TreeSet(Comparator c)

实战演练

例:TreeSetDemo.java

```java
import java.util.*;
public class TreeSetDemo{
    public static void main(String[] args){
Set ts = new TreeSet<>(); 
String[] s = new String[]{"one","two","three","four"};
for (int i = 0; i < s.length; i++){
          ts.add(s[i]);    // TreeSet中的元素将自动排序
       }
       System.out.println(ts);
    }
}

```

在这里插入图片描述

  • TreeSet类实现了SortedSet接口中的常用方法:

    ```java
    E first(): 返回有序集合中的第一个元素。
    E last(): 返回有序集合中的最后一个元素。
    SortedSet subset(E from, E to): 返回从元素from到to(不包含)结束的子有序集合。
    SortedSet headset(E to): 返回小于元素to的子有序集合。
    SortedSet tailset(E from): 返回大于等于元素from的子有序集合。
    Comparator comparator(): 返回与该有序集合相关的比较器,若集合采用自然顺序,返回null。

    ```

实战演练

例:SortedSetDemo.java

```java
import java.util.*;
public class SortedSetDemo{
public static void main(String[] args) {    
SortedSet set = new TreeSet<>();
set.add("one");
set.add("two");
set.add("three");
    System.out.println(set);  //[one, three, two]
    System.out.println(set.first());
    System.out.println(set.last());
    System.out.println(set.subSet("one", "three"));
    System.out.println(set.headSet("two"));
    System.out.println(set.tailSet("three"));
    System.out.println(set.comparator());
}
}

```

在这里插入图片描述

对象顺序

  • 所谓自然顺序(natural order),是指集合对象实现了Comparable接口的compareTo()方法,对象则根据该方法排序。
  • 如果需要指定新的比较规则,可以定义一个类实现Comparator接口 ,然后为集合提供一个新的比较器。

实战演练

例: 使用TreeSet类实现字符串的正序及逆序排序。

```java
import java.util.*;
public class DescSortDemo{
  public static void main(String[] args){
     String[] s = {"China", "England","France","America","Russia",};
     Set ts = new TreeSet<>();
     for(int i = 0; i < s.length; i ++)
         ts.add(s[i]);
     System.out.println(ts);
     //使用Lambda表达式实现字符串倒序
     ts = new TreeSet<>((String s1, String s2) -> s2.compareTo(s1)); 
     // 将数组s中的元素添加到TreeSet对象中
     for(int i = 0; i < s.length; i ++)
          ts.add(s[i]);
     System.out.println(ts);
  }
}

```

在这里插入图片描述

综合实例

在Java中,Set是一个不包含重复元素的集合。Set接口主要由HashSet、LinkedHashSet和TreeSet等类实现,每个实现类都有其特定的用途和特性。下面,我将给出一个使用HashSet的简单例子,因为HashSet是Set接口的一个常用实现,它基于哈希表实现,不保证集合的迭代顺序。

```java
import java.util.HashSet;  
import java.util.Iterator;  
import java.util.Set;

public class SetExample {  
    public static void main(String[] args) {  
        // 创建一个HashSet对象  
        Set mySet = new HashSet<>();

        // 向HashSet中添加元素  
        mySet.add("Apple");  
        mySet.add("Banana");  
        mySet.add("Cherry");  
        mySet.add("Date"); // 注意:即使再添加一次"Apple",它也不会被重复添加  
        mySet.add("Apple");

        // 遍历HashSet  
        System.out.println("Set contains the following elements:");  
        Iterator iterator = mySet.iterator();  
        while(iterator.hasNext()) {  
            String element = iterator.next();  
            System.out.println(element);  
        }

        // 检查Set是否包含某个元素  
        if(mySet.contains("Banana")) {  
            System.out.println("The set contains Banana.");  
        }

        // Set的大小  
        System.out.println("Size of the set: " + mySet.size());

        // 移除元素  
        mySet.remove("Cherry");  
        System.out.println("After removing Cherry, the set contains:");  
        for(String str : mySet) { // 使用增强的for循环遍历Set  
            System.out.println(str);  
        }

        // 清空Set  
        mySet.clear();  
        System.out.println("After clearing the set, is it empty? " + mySet.isEmpty());  
    }  
}

```

这段代码首先创建了一个HashSet的实例,并向其中添加了一些字符串元素(包括一个重复的元素,但HashSet不会存储重复元素)。然后,它使用Iterator遍历了集合中的所有元素,并打印出来。接着,它检查集合是否包含某个特定元素(在这个例子中是"Banana"),并输出了集合的大小。之后,它移除了集合中的一个元素(“Cherry”),并再次遍历集合以显示更改后的内容。最后,它清空了集合,并检查集合是否为空。
博主用心写,读者点关注,互动传真情,知识不迷路。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/4988.html

(0)
LomuLomu
上一篇 2024 年 12 月 31 日
下一篇 2024 年 12 月 31 日

相关推荐

  • 2024年最新MacBook苹果电脑安装JDK8、JDK11、JDK17、JDK22教程,配置环境变量 + 快速切换JDK版本

    本帖发布日期:2024年01月26日,全网最新教程整理。 2024年02月01日更新:环境变量新增jdk17配置代码。 2024年05月13日更新:记录解决添加maven后不能自动切换jdk版本。 2024年06月16日更新:友情提醒:如果是m芯片,推荐下载arm版本。 2024年08月08日更新:新增JDK22版本安装。 2024年11月28日更新:更新排…

    2024 年 12 月 31 日
    79500
  • Python 潮流周刊#80:Django 项目性能调优(摘要)

    由 Python猫 精心策划,本周刊汇集了全球精选的 250+ 资讯,为你呈现最有价值的文章、教程、开源项目、软件工具、音视频内容以及热门话题。我们的目标是助力每一位读者提升 Python 技能,并在职业和副业中实现收入增长。 本期精选了 12 篇精选文章,12 个开源项目,以及 3 个音视频资源,总字数约 2100 字。 以下是本期内容概览: **[🦄 文…

    未分类 2024 年 12 月 24 日
    40000
  • 【java-数据结构篇】揭秘 Java LinkedList:链表数据结构的 Java 实现原理与核心概念

    我的个人主页我的专栏:Java-数据结构 ,希望能帮助到大家!!!点赞❤ 收藏❤ 目录 1. Java LinkedList 基础 1.1 LinkedList 简介1.2 LinkedList 的实现原理1.3 LinkedList 与 ArrayList 的区别 2. 链表基础 2.1 链表的定义与种类2.2 单链表与双链表的区别2.3 循环链表与普通链…

    2025 年 1 月 10 日
    36200
  • 深入解析Java中的JSONObject操作指南

    文章大纲 Java中JSONObject的全面解析 第一部分:概述 第二部分:JSONObject的基础应用 1、初始化JSONObject 2、数据插入方法 3、数值提取技巧 第三部分:JSONObject进阶功能 1、对象遍历实现 2、字符串转换JSON 3、JSONArray协同操作 4、数据修改与移除 第四部分:异常处理机制 1. 键值验证 2. 安…

    2025 年 5 月 19 日
    49200
  • 华为OD机试E卷 –英文输入法–24年OD统一考试(Java & JS & Python & C & C++)

    文章目录 题目描述 输入描述 输出描述 用例 JS算法源码 Java算法源码 python算法源码 c算法源码 c++算法源码 题目描述 主管期望你来实现英文输入法单词联想功能。需求如下:• 依据用户输入的单词前缀,从已输入的英文语句中联想出用户想输入的单词,按字典序输出联想到的单词序列,• 如果联想不到,请输出用户输入的单词前缀。 注意: 英文单词联想时,…

    未分类 2025 年 1 月 15 日
    51700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信