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

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

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

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

集合——Set

  • Set接口及实现类
    • HashSet类
      • 实战演练
    • 用Set对象实现集合操作
    • TreeSet类
      • 实战演练
      • 实战演练
    • 对象顺序
      • 实战演练
        • 综合实例

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

import java.util.*;public class HashSetDemo {public static void main(String[] args) {
Set<String> 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

import java.util.*;
public class TreeSetDemo{public static void main(String[] args){
Set<String> 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接口中的常用方法:
E first(): 返回有序集合中的第一个元素。
E last(): 返回有序集合中的最后一个元素。
SortedSet<E> subset(E from, E to): 返回从元素from到to(不包含)结束的子有序集合。
SortedSet<E> headset(E to): 返回小于元素to的子有序集合。
SortedSet<E> tailset(E from): 返回大于等于元素from的子有序集合。
Comparator<? super E> comparator(): 返回与该有序集合相关的比较器,若集合采用自然顺序,返回null

实战演练

例:SortedSetDemo.java

import java.util.*;
public class SortedSetDemo{
public static void main(String[] args) {    
SortedSet<String> 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类实现字符串的正序及逆序排序。

import java.util.*;
public class DescSortDemo{public static void main(String[] args){String[] s = {"China", "England","France","America","Russia",};Set<String> 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接口的一个常用实现,它基于哈希表实现,不保证集合的迭代顺序。

import java.util.HashSet;  
import java.util.Iterator;  
import java.util.Set;  public class SetExample {  public static void main(String[] args) {  // 创建一个HashSet对象  Set<String> 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<String> 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<String>的实例,并向其中添加了一些字符串元素(包括一个重复的元素,但HashSet不会存储重复元素)。然后,它使用Iterator遍历了集合中的所有元素,并打印出来。接着,它检查集合是否包含某个特定元素(在这个例子中是"Banana"),并输出了集合的大小。之后,它移除了集合中的一个元素(“Cherry”),并再次遍历集合以显示更改后的内容。最后,它清空了集合,并检查集合是否为空。
博主用心写,读者点关注,互动传真情,知识不迷路。

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

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

相关文章

Google大数据架构技术栈

数据存储层 Colossus Colossus作为Google下一代GFS&#xff08;Google File System&#xff09;。 GFS本身存在一些不足 单主瓶颈 GFS 依赖单个主节点进行元数据管理&#xff0c;随着数据量和访问请求的增长&#xff0c;出现了可扩展性瓶颈。想象一下&#xff0c;只有一位…

人工智能——猴子摘香蕉问题

一、实验目的 求解猴子摘香蕉问题&#xff0c;根据猴子不同的位置&#xff0c;求解猴子的移动范围&#xff0c;求解对应的过程&#xff0c;针对不同的目标状态进行求解。 二、实验内容 根据场景有猴子、箱子、香蕉&#xff0c;香蕉挂天花板上。定义多种谓词描述位置、状态等…

Git使用详解:从安装到精通

前言 什么是Git Git是一个分布式版本控制工具&#xff0c;主要用于管理开发过程中的源代码文件&#xff08;Java类、xml文件、html页面等&#xff09;&#xff0c;在软件开发过程中被广泛使用。 可以理解&#xff1a; git是一个管理源代码的工具&#xff0c;主要用于企业团队开…

Python编码系列—Python原型模式:深克隆与高效复制的艺术

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

通信工程学习:什么是FDMA频分多址

FDMA&#xff1a;频分多址 FDMA&#xff08;Frequency Division Multiple Access&#xff0c;频分多址&#xff09;是一种在无线通信领域广泛应用的多址技术。该技术通过将可用的频谱资源按频率划分&#xff0c;把传输频带划分为若干较窄且互不重叠的子频带&#xff08;或称信道…

【C语言】malloc()函数详解(动态内存开辟函数)

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:C语言 ⚙️操作环境:Visual Studio 2022 目录 一.malloc()函数简介 1.函数功能 2.函数参数 &#x1f4cc;size_t size 3.函数返回值 4.函数头文件 5.函数生成空间(与calloc区别) 二.malloc()函数的具体使用 1.使…

STL值list

list容器 头文件&#xff1a;#include<list> - list是一个双向链表容器&#xff0c;可高效地进行插入删除元素 - list不可以随机存取元素&#xff0c;所以不支持at.(pos)函数与[]操作符 注&#xff1a;list使用迭代器访问数据时可以一步一步走自增自减&#xff08;即…

分享一个基于微信小程序的居家养老服务小程序 养老服务预约安卓app uniapp(源码、调试、LW、开题、PPT)

&#x1f495;&#x1f495;作者&#xff1a;计算机源码社 &#x1f495;&#x1f495;个人简介&#xff1a;本人 八年开发经验&#xff0c;擅长Java、Python、PHP、.NET、Node.js、Android、微信小程序、爬虫、大数据、机器学习等&#xff0c;大家有这一块的问题可以一起交流&…

【苍穹外卖】总结

1 pom 依赖 1.1 MyBatis Spring 用于简化 MyBatis 与 Spring Boot 的集成&#xff0c;提供了对 MyBatis 框架的自动配置支持&#xff0c;简化了数据访问层的开发 1.2 Lombok Lombok 是一个 Java 库&#xff0c;能够通过注解自动生成常见的代码&#xff08;如 getter、setter、…

看Threejs好玩示例,学习创新与技术(三)

本文接上篇内容&#xff0c;继续挖掘应用ThreeJS的一些创新算法。 1、获得鼠标移动对应的地理位置 这个算法如果放在几年前&#xff0c;那肯定会难倒一帮人的。因为是三维投影涉及矩阵变换及求逆&#xff0c;而且还是投影模式下的。在Project Texture这个示例中&#xff0c;作…

Apache-wed服务器环境的安装

一。安装httpd并且开启httpd yum install httpd systemctl start httpd 二。关闭防火墙 systemctl stop firewall 三。常规配置wed服务 mkdir /www vim index.html&#xff08;里面写入自己的内容&#xff09; chmod 755 index.htm chmod 755 /www vim /etc/httpd/co…

从冯唐的成事心法 看SAP协助企业战略落地到信息化

冯唐的《成事心法》是一部结合古代智慧和现代管理理念的著作&#xff0c;通过分析和解读古代名臣张居正的管理方法&#xff0c;提出了一套实用的成事之道。这本书的结构循序渐进&#xff0c;讲解了如何在工作和生活中实现目标、解决问题。以下是《成事心法》的主要结构和内容概…

【Node.js】初识微服务

概述 Node.js 的微服务架构是一种通过将应用程序分解为独立的、松耦合的小服务的方式进行系统设计。 每个微服务负责处理一个特定的业务功能&#xff0c;并且这些服务可以独立开发、部署、扩展和管理&#xff0c;并且可以通讯。 它的核心思想就是解耦。 微服务和微前端是类…

FastText 和 Faiss 的初探了解

概览 大模型目前已经是如火如荼的程度&#xff0c;各个大厂都有推出面向大众的基础大模型&#xff0c;同时诸多行业也有在训练专有大模型&#xff0c;而大模型的发展由来却是经过多年从文本检索生成、深度学习、自然语言处理&#xff0c;在Transformer架构出来后&#xff0c;才…

前端基础知识+算法(一)

文章目录 算法二分查找条件注意方式基本原理左闭右闭正向写法 左闭右开正向写法 前端基础知识定时器及清除盒子垂直水平居中的方式垂直水平1.flex布局2.grid布局3.定位对于块级元素 解决高度塌陷的方式1.给父元素一个固定的高度2.给父元素添加属性 overflow: hidden;3.在子元素…

ip映射域名,一般用于mysql和redis的固定映射,方便快捷打包

举个例子 192.168.3.101mysql映射到mysql.smartlink.com 192.168.3.101redis redis.smartlink.com 要将IP地址映射到域名&#xff0c;可以通过几种方式实现&#xff0c;包括修改本地主机文件&#xff08;仅适用于本地开发环境&#xff09;、设置DNS解析&#xff08;适用于生产环…

IDEA-调用Restful接口

告别Swagger3/Apifox/Postman Swagger3&#xff08;丝袜哥&#xff09; 地址&#xff1a;REST API Documentation Tool | Swagger UI简介&#xff1a;在java代码里面增加注解生成接口文档 在代码里面增加注解 RestController RequestMapping("api/v1/user") Api(ta…

Java外卖小程序管理系统

技术架构&#xff1a; springboot ssm mysql redis 有需要该项目的小伙伴可以添加我Q&#xff1a;598748873&#xff0c;备注&#xff1a;CSDN 功能描述&#xff1a; 商品管理&#xff1a;新增商品、所有商品 菜单管理&#xff1a;菜单管理、菜单分类 订单管理&#x…

<<编码>> 第 12 章 二进制加法器--8位加法器 示例电路

8 位加法器内部结构 info::操作说明 鼠标单击逻辑输入切换 0|1 状态 primary::在线交互操作链接 https://cc.xiaogd.net/?startCircuitLinkhttps://book.xiaogd.net/code-hlchs-examples/assets/circuit/code-hlchs-ch12-08-8-bit-adder-internal.txt 8 位加法器 info::操作说…

只要不逾期就行了吗?如何守护好你的“第二张身份证“!

在这个时代&#xff0c;信用记录已远远超越了金融交易的范畴&#xff0c;它如同一根无形的纽带&#xff0c;将我们生活的各个领域紧密相连。近闻有人甚至在步入婚姻殿堂前&#xff0c;也要细致核查对方的信用状况&#xff0c;毕竟&#xff0c;这关乎到共同生活的基石与未来幸福…