Java集合进阶(三)
文章目录
- 一、Map
- 1. 概述
- 2. 基本功能
- 3. 遍历
- 4. 遍历学生对象
- 5. 集合嵌套
- 6. 统计字符出现次数
- 二、Collections
- 1. 常用方法
- 2. 学生对象排序
- 三、模拟斗地主
一、Map
1. 概述
Interface Map<K, V>:K 是键的类型,V 是值的类型。
将键映射到值的对象,不能包含重复的键,每个键可以映射到最多一个值。
举例:学生的学号和姓名,学号是键,姓名是值。
tyut001 刘德华
tyut002 张学友
tyut003 成吉思汗
创建 Map 集合的对象:
采用多态的方式,具体的实现类是 HashMap。
//Test.javapackage com.zxe;import java.util.HashMap;
import java.util.Map;public class Test {public static void main(String[] args) {Map<String, String> map = new HashMap<>();map.put("tyut001", "刘德华");map.put("tyut002", "张学友");map.put("tyut003", "成吉思汗");map.put("tyut003", "程咬金");System.out.println(map);}
}
利用 HashMap 保证了元素的唯一性,键是唯一的,当出现重复的键时,后者会把前者的值替换掉!
2. 基本功能
//打印输出键值对中所有的值package com.zxe;import java.util.Collection;
import java.util.HashMap;
import java.util.Map;public class Test {public static void main(String[] args) {Map<String, String> map = new HashMap<>();map.put("tyut001", "刘德华");map.put("tyut002", "张学友");map.put("tyut003", "成吉思汗");Collection<String> values = map.values();for (String s : values) {System.out.println(s);}}
}
3. 遍历
(1)方式一
遍历思路:
① 先获取所有键的集合,用 keySet() 方法实现;
② 然后遍历键的集合,获取到每一个键,用增强 for 实现;
③ 根据键全找值,用 get(Object key) 方法实现。
package com.zxe;import java.util.HashMap;
import java.util.Map;
import java.util.Set;public class Test {public static void main(String[] args) {Map<String, String> map = new HashMap<>();map.put("tyut001", "刘德华");map.put("tyut002", "张学友");map.put("tyut003", "成吉思汗");Set<String> key = map.keySet();for (String k : key) {String value = map.get(k);System.out.println(k + ", " + value);}}
}
(2)方式二
遍历思路:
① 直接获取所有键值对对象的集合,用 entrySet() 方法实现,集合为 Set 型,每一个键值对对象用 Map.Entry<String, String> 接收;
② 遍历键值对对象的集合,得到每一个键值对对象,用增强 for 实现,得到每一个 Map.Entry;
③ 根据键值对对象获取键和值,用 getKey() 得到键,用 getValue() 得到值。
package com.zxe;import java.util.HashMap;
import java.util.Map;
import java.util.Set;public class Test {public static void main(String[] args) {Map<String, String> map = new HashMap<>();map.put("tyut001", "刘德华");map.put("tyut002", "张学友");map.put("tyut003", "成吉思汗");Set<Map.Entry<String, String>> entries = map.entrySet();for (Map.Entry<String, String> entry : entries) {String key = entry.getKey();String value = entry.getValue();System.out.println(key + ", " + value);}}
}
4. 遍历学生对象
需求:创建一个 HashMap 集合,键是学号(String),值是学生对象(Student),存储三个键值对元素,并遍历。
思路:
① 定义学生类;
② 创建 HashMap 集合对象;
③ 创建学生对象;
④ 把学生添加到集合;
⑤ 遍历集合。
//Student.javapackage com.zxe;public class Student {private String name;private int age;private String sex;@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +", age=" + age +", sex='" + sex + '\'' +'}';}public Student() {}public Student(String name, int age, String sex) {this.name = name;this.age = age;this.sex = sex;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}
}
//Test.javapackage com.zxe;import java.util.HashMap;
import java.util.Map;
import java.util.Set;public class Test {public static void main(String[] args) {Student s1 = new Student("刘德华", 60, "男");Student s2 = new Student("张学娥", 21, "女");Student s3 = new Student("李华", 14, "男");String sno1 = "001";String sno2 = "002";String sno3 = "003";HashMap<String, Student> allstudent = new HashMap<>();allstudent.put(sno1, s1);allstudent.put(sno2, s2);allstudent.put(sno3, s3);Set<Map.Entry<String, Student>> entries = allstudent.entrySet();for (Map.Entry<String, Student> entry : entries) {String key = entry.getKey();Student value = entry.getValue();System.out.println(key + ", " + value);}}
}
思考一下,如果我们的键是用户定义的学生对象,值是居住地址,这时候如何保证学生对象成员变量的值不重复的呢?
在学生类中重写两个方法,hashCode() 和 equals(),这两个方法在之前的内容中有讲过,Alt + Insert 快捷键自动生成。
以学生对象 s1 和 s2 为例,HashMap 保证的唯一性是指,该集合中不允许添加两个或更多的 s1,但可以添加一个 s1 和一个 s2,即使 s1 和 s2 中的内容一模一样,但它并不在意二者内容如何;而重写 hashCode() 和 equals() 方法保证的唯一性是指,它不允许两个对象中出现完全相同的内容。所以要想保证真正意义上的唯一性,应同时使用 HashMap 和 hashCode()、equals() 方法!
5. 集合嵌套
//Test.javapackage com.zxe;import java.util.*;public class Test {public static void main(String[] args) {HashMap<Integer, String> hm1 = new HashMap<>();hm1.put(1, "孙策");hm1.put(2, "大桥");HashMap<Integer, String> hm2 = new HashMap<>();hm2.put(3, "吕布");hm2.put(4, "貂蝉");ArrayList<HashMap<Integer, String>> a = new ArrayList<>();a.add(hm1);a.add(hm2);System.out.println(a);}
}
直接输出,或者也可以用遍历的方式输出:
//方法一
for (HashMap<Integer, String> hm : a) {Set<Map.Entry<Integer, String>> entries = hm.entrySet();for (Map.Entry<Integer, String> entry : entries) {System.out.println(entry.getKey() + ", " + entry.getValue());}}//方法二
for (HashMap<Integer, String> hm : a) {Set<Integer> keys = hm.keySet();for (Integer key : keys) {String value = hm.get(key);System.out.println(key + ", " +value);}}
6. 统计字符出现次数
需求:键盘录入一个字符串,要求统计字符串中每个字符串出现的次数。
思路:
① 键盘录入一个字符串;
② 创建 HashMap 集合,键是 Character,值是 Integer;
③ 遍历字符串,得到每一个字符;
④ 拿得到的每一个字符作为键到 HashMap 集合中去找对应的值,看其返回值,返回值为 null 说明该字符在 HashMap 集合中不存在,就把该字符作为键,1 作为值存储,如果返回值不是 null 说明该字符在 HashMap 集合中存在,把该键所对应的值加 1,然后重新存储该键值对;
⑤ 遍历 HashMap 集合,得到键和值,按照要求进行拼接。
//Test.javapackage com.zxe;import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;public class Test {public static void main(String[] args) {Scanner sc = new Scanner(System.in);System.out.println("请输入一个字符串:");String str = sc.nextLine();HashMap<Character, Integer> hm = new HashMap<>();for (int i = 0; i < str.length(); i++) {Character c = str.charAt(i);if (hm.containsKey(c)) {Integer newValue = hm.get(c) + 1;hm.put(c, newValue);} else {hm.put(c, 1);}}Set<Map.Entry<Character, Integer>> entries = hm.entrySet();for (Map.Entry<Character, Integer> entry : entries) {Character letter = entry.getKey();Integer num = entry.getValue();System.out.println(letter + "出现了" + num +"次!");}}
}
二、Collections
1. 常用方法
Collections 是针对集合操作的工具类。
常用方法:
① sort(),将指定的列表按升序排序;
② reverse(),反转指定列表中元素的顺序;
③ shuffle(),使用默认的随机源随机排列指定的列表。
//Test.javapackage com.zxe;import java.util.ArrayList;
import java.util.Collections;
import java.util.List;public class Test {public static void main(String[] args) {List<Integer> list = new ArrayList<>();list.add(1);list.add(6);list.add(7);list.add(2);list.add(4);list.add(9);Collections.reverse(list);System.out.println("反转:" + list);Collections.sort(list);System.out.println("升序排序:" + list);Collections.shuffle(list);System.out.println("随机排序:" + list);}
}
这是升序排序的方法,如果想要降序排序,完全可以先对集合进行升序排序,然后再反转,就得到了降序集合。
2. 学生对象排序
需求:ArrayList 存储学生对象,使用 Collections 对 ArrayList 进行排序,要求按照年龄从大到小排序,年龄相同时,按照姓名的字母顺序排序。
//Test.javapackage com.zxe;import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;public class Test {public static void main(String[] args) {Student s1 = new Student("zhangliang", 17);Student s2 = new Student("lvbu", 23);Student s3 = new Student("jiangziya", 31);Student s4 = new Student("kuangtie", 23);Student s5 = new Student("sunce", 27);ArrayList<Student> stus = new ArrayList<>();stus.add(s1);stus.add(s2);stus.add(s3);stus.add(s4);stus.add(s5);Collections.sort(stus, new Comparator<Student>() {@Overridepublic int compare(Student o1, Student o2) {int num = o1.getAge() - o2.getAge();int num2 = num == 0 ? o1.getName().compareTo(o2.getName()) : num;return num2;}});for (Student s : stus) {System.out.println(s.getName() + ", " + s.getAge());}}
}
这里排序的时候 sort() 方法是需要传入两个参数的,第一个就是要排序的集合,第二个需要指定一个比较器,之前我们学过的两种排序方法,自然排序和比较器排序,自然排序需要在学生类里面实现一个接口,这边我们通过比较器的方式来实现排序。
三、模拟斗地主
需求:通过程序实现斗地主过程中的洗牌、发牌和看牌,要求对牌进行排序。
思路:
① 创建 HashMap,键是编号,值是牌;
② 创建 ArrayList,存储编号;
③ 创建花色数组和点数数组;
④ 从 0 开始往 HashMap 里面存储编号,并存储对应的牌,同时往 ArrayList 里面存储编号;
⑤ 洗牌(洗的是编号),用 Collections 的 shuffle() 方法实现;
⑥ 发牌(发的也是编号),为了保证编号是排序的,创建 TreeSet 集合接收;
⑦ 定义方法看牌,遍历 TreeSet 集合,获取编号,到 HashMap 集合去到对应的牌;
⑧ 调用看牌方法。
//Test.javapackage com.zxe;import java.util.*;public class Test {public static void main(String[] args) {HashMap<Integer, String> pokers = new HashMap<>();ArrayList<Integer> indexs = new ArrayList<>();String[] colors = {"♥", "♠", "♦", "♣"};String[] numbers = {"A", "2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K"};String[] kings = {"大王", "小王"};Integer index = 0;for (String number : numbers) {for (String color : colors) {pokers.put(index, color + number);indexs.add(index);index++;}}for (String king : kings) {pokers.put(index, king);indexs.add(index);index++;}Collections.shuffle(indexs);TreeSet<Integer> indexsOfPlayer1 = new TreeSet<>();TreeSet<Integer> indexsOfPlayer2 = new TreeSet<>();TreeSet<Integer> indexsOfPlayer3 = new TreeSet<>();TreeSet<Integer> indexsRetains = new TreeSet<>();for (int i = 0; i < indexs.size(); i++) {Integer in = indexs.get(i);if (i >= indexs.size() - 3) {indexsRetains.add(in);} else {switch (i % 3) {case 0:indexsOfPlayer1.add(in);break;case 1:indexsOfPlayer2.add(in);break;default:indexsOfPlayer3.add(in);break;}}}showPokers("刘德华", indexsOfPlayer1, pokers);showPokers("张学友", indexsOfPlayer2, pokers);showPokers("程咬金", indexsOfPlayer3, pokers);System.out.println("\n底牌是:");for (Integer i : indexsRetains) {String retain = pokers.get(i);System.out.print(retain + " ");}}public static void showPokers(String name, TreeSet<Integer> indexsOfPlayer, HashMap<Integer, String> pokers) {System.out.println("\n" + name + "的牌:");for (Integer i : indexsOfPlayer) {String poker = pokers.get(i);System.out.print(poker + " ");}}
}
相关文章:

Java集合进阶(三)
文章目录一、Map1. 概述2. 基本功能3. 遍历4. 遍历学生对象5. 集合嵌套6. 统计字符出现次数二、Collections1. 常用方法2. 学生对象排序三、模拟斗地主一、Map 1. 概述 Interface Map<K, V>:K 是键的类型,V 是值的类型。 将键映射到值的对象&…...

【网络】什么是RPC?RPC与HTTP有什么关系?
文章目录RPC是什么RPC和HTTP的关系和区别[附]关于REST论文中提到的"HTTP不是RPC"重点参考 凤凰架构-远程过程调用 既然有HTTP为什么还要有RPC? RPC是什么 RPC(Remote Procedure Call):即远程过程调用,目的是为了让计算机能够跟调用…...

[手撕数据结构]栈的深入学习-java实现
CSDN的各位uu们你们好,今天千泽带来了栈的深入学习,我们会简单的用代码实现一下栈, 接下来让我们一起进入栈的神奇小世界吧!0.速览文章一、栈的定义1. 栈的概念2. 栈的图解二、栈的模拟实现三.栈的经典使用场景-逆波兰表达式总结一、栈的定义 1. 栈的概念 栈:一种…...

2.线性表的顺序表示
数据结构很重要! 数据结构很重要!!! 数据结构很重要!!!! 思考 1.线性表的顺序表示内容有哪些?(What) 2.为什么要学线性表的顺序表示? ? (Why)…...

eps文件删除了能恢复吗?恢复误删eps文件的三种方法
eps文件格式专为矢量图像和图形而设计。虽然没有被广泛使用,但它仍然受到各种插画家和平面设计师的钟爱。eps文件十分适合创建徽标和商标设计,主要应用见于广告牌、海报和横幅。可是在使用设备过程中,难免会遇到数据丢失问题,如果…...
【C++】运算符重载练习——Date 类
文章目录👉日期类介绍👈👉日期类实现👈📕 成员变量📕 构造函数📕 对应月份天数📕 赋值重载📕 比较运算符重载📕 计算 运算符重载👉源代码…...

Redis学习(13)之Lua脚本【环境准备】
文章目录一 Lua入门环境准备1.1 Lua简介1.2 Linux 系统安装Lua1.2.1 Lua 下载1.2.2 Lua 安装1.3 Hello World1.3.1 命令行模式1.3.2 脚本文件模式1.3.3 两种脚本运行方式1.4 Win安装Lua1.4.1 LuaForWindows的安装1.4.2 SciTE修改字体大小1.4.3 SciTE中文乱码1.4.4 SciTE快捷键工…...

关于BLE的一些知识总结
数据包长度对于BLE4.0/4.1来说,一个数据包的有效载荷最大为20字节对于BLE4.2以上,数据包的有效载荷扩大为251字节传输速率在不考虑跳频间隔的情况下,最大传输速率为:1)BLE4.0/4.1的理论吞吐率为39kb/s;2&am…...

Spring框架源码分析一
如何看源码(方法论)不要忽略源码中的注释使用翻译工具先梳理脉络,然后梳理细节即总分总,先总体过一遍,再看细节,再做一个总结大胆猜测(8分靠猜),小心验证,再调…...

CSS常用内容总结(扫盲)
文章目录前言相关概念【了解】脚本语言什么是脚本语言脚本语言有什么特点常见的脚本语言什么是动态语言,什么是静态语言动态语言和静态语言两者之间有何区别CSSCSS是什么CSS的特点一、CSS代码怎么写基本语法规则引入方式内部样式内联样式表外部样式代码风格二、CSS的…...

Java启蒙之语言基础
目录 一.Java标识符和关键字 1.1Java标识符 1.2Java关键字 二.数据类型和变量的概述和关系 2.1Java变量 2.2Java的数据类型 2.2.1数据类型的分类的概述 2.2.2数据类型的转换 3.Java运算符 总结 😽个人主页:tq02的博客_CSDN博客-领域博主 &#…...
数据库系统--T-SQL数据查询功能-多表查询(超详细/设计/实验/作业/练习)
目录课程名:数据库系统内容/作用:设计/实验/作业/练习学习:T-SQL数据查询功能-多表查询一、前言二、环境与设备三、内容四、内容练习题目:对应题目答案:五、总结课程名:数据库系统 内容/作用:设…...
Spring Boot 3.0系列【14】核心特性篇之Configuration相关注解汇总介绍
有道无术,术尚可求,有术无道,止于术。 本系列Spring Boot版本3.0.3 源码地址:https://gitee.com/pearl-organization/study-spring-boot3 文章目录 前言@Configuration@ConfigurationProperties@EnableConfigurationProperties@ConfigurationPropertiesScan@Configuratio…...
[ubuntu][jetson]给jetson增加swap空间类似于给windows加虚拟内存
具体操作如下: #打开性能模式 sudo nvpmodel -m 0 && sudo jetson_clocks #增加swap空间,防止爆内存 swapoff -a sudo fallocate -l 15G /swapfile sudo chmod 600 /var/swapfile sudo mkswap /swapfile sudo swapon /swapfile…...

小黑子—Java从入门到入土过程:第二章
Java零基础入门2.0Java系列第二章1. 注释和关键字2. 字面量3. 变量3.1 基本用法3.2 使用方式3.3 注意事项4. 变量练习5. 计算机中的数据存储5.1 计算机的存储规则5.2 进制5.3 进制间转换二进制转十八进制转十十六进制转十十进制转其他进制6. 数据类型7. 定义变量的练习8. 标识符…...
ElasticSearch搜索详细讲解与操作
全文检索基础 全文检索流程 流程: #mermaid-svg-7Eg2qFEl06PIEAxZ {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-7Eg2qFEl06PIEAxZ .error-icon{fill:#552222;}#mermaid-svg-7Eg2qFEl06PIEAxZ .error…...

web实现太极八卦图、旋转动画、定位、角度、坐标、html、css、JavaScript、animation
文章目录前言1、html部分2、css部分3、JavaScript部分4、微信小程序演示前言 哈哈 1、html部分 <div class"great_ultimate_eight_diagrams_box"><div class"eight_diagrams_box"><div class"eight_diagrams"><div class&…...

【LeetCode】33. 搜索旋转排序数组、1290. 二进制链表转整数
作者:小卢 专栏:《Leetcode》 喜欢的话:世间因为少年的挺身而出,而更加瑰丽。 ——《人民日报》 目录 33. 搜索旋转排序数组 1290. 二进制链表转整数 33. 搜索旋转排序数组 33. 搜索旋转排序…...

IBM Semeru Windows 下的安装 JDK 17
要搞清楚下载那个版本,请参考文章:来聊聊 OpenJDK 和 JVM 虚拟机下载地址semeru 有认证版和非认证版,主要是因为和 OpenJ9 的关系和操作系统的关系而使用不同的许可证罢了,本质代码是一样的。在 Windows 下没有认证版,…...

Lambda表达式和steram流
目录 引言: 语法: Lambda 表达式实例: demo演示: Stream流: 引言: Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性。 Lambda 允许把函数作为一个方法的参数(函…...

python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...
SciencePlots——绘制论文中的图片
文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
蓝桥杯 冶炼金属
原题目链接 🔧 冶炼金属转换率推测题解 📜 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V,是一个正整数,表示每 V V V 个普通金属 O O O 可以冶炼出 …...

人机融合智能 | “人智交互”跨学科新领域
本文系统地提出基于“以人为中心AI(HCAI)”理念的人-人工智能交互(人智交互)这一跨学科新领域及框架,定义人智交互领域的理念、基本理论和关键问题、方法、开发流程和参与团队等,阐述提出人智交互新领域的意义。然后,提出人智交互研究的三种新范式取向以及它们的意义。最后,总结…...

Netty从入门到进阶(二)
二、Netty入门 1. 概述 1.1 Netty是什么 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. Netty是一个异步的、基于事件驱动的网络应用框架,用于…...
GitHub 趋势日报 (2025年06月06日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 590 cognee 551 onlook 399 project-based-learning 348 build-your-own-x 320 ne…...

Elastic 获得 AWS 教育 ISV 合作伙伴资质,进一步增强教育解决方案产品组合
作者:来自 Elastic Udayasimha Theepireddy (Uday), Brian Bergholm, Marianna Jonsdottir 通过搜索 AI 和云创新推动教育领域的数字化转型。 我们非常高兴地宣布,Elastic 已获得 AWS 教育 ISV 合作伙伴资质。这一重要认证表明,Elastic 作为 …...

Python训练营-Day26-函数专题1:函数定义与参数
题目1:计算圆的面积 任务: 编写一个名为 calculate_circle_area 的函数,该函数接收圆的半径 radius 作为参数,并返回圆的面积。圆的面积 π * radius (可以使用 math.pi 作为 π 的值)要求:函数接收一个位置参数 radi…...
React从基础入门到高级实战:React 实战项目 - 项目五:微前端与模块化架构
React 实战项目:微前端与模块化架构 欢迎来到 React 开发教程专栏 的第 30 篇!在前 29 篇文章中,我们从 React 的基础概念逐步深入到高级技巧,涵盖了组件设计、状态管理、路由配置、性能优化和企业级应用等核心内容。这一次&…...