JAVA题目笔记(十七)TreeSet对象排序+Map集合练习

一、TreeSet对象排序:

需求:

public class Student implements Comparable<Student>{private String name;private int age;private int grade_Yu;private int grade_Shu;private int grade_Yin;private int sum=this.grade_Yin+this.grade_Shu+this.grade_Yu;public Student(){}public Student(String name,int age,int getGrade_Yu,int getGrade_Shu,int getGrade_Yin){this.name=name;this.age=age;this.grade_Yu=grade_Yu;this.grade_Shu=grade_Shu;this.grade_Yin=grade_Yin;}@Overridepublic int compareTo(Student o) {int i=this.sum-o.sum;i=i==0?this.grade_Yu-o.grade_Yu:i;i=i==0?this.grade_Shu-o.grade_Shu:i;i=i==0?this.age-o.age:i;i=i==0?this.name.compareTo(o.name):i;return i;}@Overridepublic String toString(){return "["+this.name+" "+this.age+"]";}
}
import java.util.TreeSet;
public class Main {public static void main(String[] args) {TreeSet<Student> treeSet=new TreeSet<>();Student stu1=new Student("zhangsan",23,90,99,50);Student stu2=new Student("lisi",24,90,98,50);Student stu3=new Student("wangwu",25,95,100,30);Student stu4=new Student("zhaoliu",26,60,99,70);Student stu5=new Student("qianqi",26,70,80,70);treeSet.add(stu1);treeSet.add(stu2);treeSet.add(stu3);treeSet.add(stu4);treeSet.add(stu5);System.out.println(treeSet);  //[[zhangsan 23], [lisi 24], [wangwu 25], [qianqi 26], [zhaoliu 26]]}
}

二、Map集合案例-统计投票人数

需求:

import java.util.*;
import java.util.function.BiConsumer;public class Main {public static void main(String[] args) {//统计投票人数//1、创建集合对象HashMap<String,Integer> map=new HashMap<>();int n1=0,n2=0,n3=0,n4=0;//4个景点map.put("A",n1);map.put("B",n2);map.put("C",n3);map.put("D",n4);//模拟80个学生投票Random r=new Random();for(int i=0;i<80;i++){int choose=r.nextInt(4);if(choose==0){n1++;map.put("A",n1);}else if(choose==1){n2++;map.put("B",n2);}else if(choose==2){n3++;map.put("C",n3);}else if(choose==3){n4++;map.put("D",n4);}}//遍历HashMapint max=0;String result=null;Set<String> sets=map.keySet();for(String set:sets){int number=map.get(set);System.out.println("地点:"+set+",人数:"+number);if(max<number) {max = number;result =set;}}System.out.println("最多的人选择:"+result+",一共有"+max+"人");}
}

三、存储学生对象并遍历

创建Student类   alt+Insert 重写HashCode 与 Equals方法

import java.util.Objects;public class Student {private String name;private int age;private String area;public Student(){}public Student(String name,int age){this.name=name;this.age=age;}@Overridepublic boolean equals(Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;Student student = (Student) o;return age == student.age && Objects.equals(name, student.name) && Objects.equals(area, student.area);}@Overridepublic int hashCode() {return Objects.hash(name, age, area);}@Overridepublic String toString(){return "[姓名:"+this.name+",年龄:"+this.age+"]";}
}
import java.util.*;
import java.util.function.BiConsumer;public class Main {public static void main(String[] args) {//存储学生对象并遍历//同姓名和同年龄的认为是同一个人//创建学生对象Student stu1=new Student("zhangsan",18);Student stu2=new Student("zhangsan",18);Student stu3=new Student("zhangwu",12);//创建HashMap集合 建是学生对象,值是籍贯//存储对象HashMap<Student,String> hm=new HashMap<>();hm.put(stu1,"nanjin");hm.put(stu2,"suzhou");hm.put(stu3,"beijin");//遍历HashMap集合//keySet方法获取所有集合中的键值Set<Student> key=hm.keySet();//增强for循环遍历for(Student s:key){String area=hm.get(s);System.out.println(s.toString()+"="+area);}//[姓名:zhangwu,年龄:12]=beijin//[姓名:zhangsan,年龄:18]=nanjin//键值对 遍历//增强for循环//获取每一个 键值对 对象Set<Map.Entry<Student,String>> entries=hm.entrySet();for(Map.Entry<Student,String> s:hm.entrySet()){Student keyy=s.getKey();String value=s.getValue();System.out.println(keyy+"="+value);}//[姓名:zhangwu,年龄:12]=beijin//[姓名:zhangsan,年龄:18]=suzhou//lambda表达式遍历hm.forEach(new BiConsumer<Student, String>() {@Overridepublic void accept(Student student, String s) {System.out.println(student+"="+s);}});//[姓名:zhangwu,年龄:12]=beijin//[姓名:zhangsan,年龄:18]=suzhou}
}

四、TreeMap集合基本应用(一)

import java.util.*;public class Main {public static void main(String[] args) {//TreeMap的基本应用//键表示整数id  值表示字符串商品名称//按id的升序排列、按id的降序排列//方法一:创建对象时构造comparator比较器对象来制定排序规则//o1为添加的元素  o2为存在的元素//返回值小于零放左边,大于放右边,为0表示重复不存储TreeMap<Integer,String> tm=new TreeMap<>(new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o1-o2;//降序  return o2-o1;}});tm.put(1,"牙膏");tm.put(5,"牙刷");tm.put(3,"纸巾");tm.put(4,"镜子");tm.put(2,"梳子");System.out.println(tm);}
}

五、TreeMap集合基本应用(二)

import java.util.Objects;public class Student implements Comparable<Student>{private String name;private int age;private String area;public Student(){}public Student(String name,int age){this.name=name;this.age=age;}@Overridepublic boolean equals(Object o) {if (this == o) return true;if (o == null || getClass() != o.getClass()) return false;Student student = (Student) o;return age == student.age && Objects.equals(name, student.name) && Objects.equals(area, student.area);}@Overridepublic int hashCode() {return Objects.hash(name, age, area);}@Overridepublic String toString(){return "[姓名:"+this.name+",年龄:"+this.age+"]";}@Overridepublic int compareTo(Student o) {//this表示添加的元素  o表示存在的元素//返回值小于0放左边,大于0放右边,等于零表示重复元素不存储//按年龄升序int i=this.age-o.age;i=i==0?this.name.compareTo(o.name):i;return i;}
}
import java.util.*;public class Main {public static void main(String[] args) {//键:学生对象,值:籍贯//按照学生年龄进行排序,年龄一样按照学生姓名进行排序,同年龄同姓名视为同一个人//创建学生对象Student stu1=new Student("jinluhao",18);Student stu2=new Student("caixukun",15);Student stu3=new Student("wangjunkai",12);Student stu4=new Student("liusi",20);Student stu5=new Student("jinluhao",18);Student stu6=new Student("zhangsan",18);//方法二实现:在类中实现Comparable接口重新制定排序规则TreeMap<Student,String> treeMap=new TreeMap<>();treeMap.put(stu1,"jiangsu");treeMap.put(stu2,"shandong");treeMap.put(stu3,"shanghai");treeMap.put(stu4,"beijing");treeMap.put(stu5,"beijing");treeMap.put(stu6,"beijing");System.out.println(treeMap);}
}

六、TreeMap集合基本应用(三)

import java.util.*;
import java.util.function.BiConsumer;public class Main {public static void main(String[] args) {//TreeMap的基本应用//统计字符串中每一个字符的出现次数//字符串:aababcabcdabcde//要求输出结果: a:  b:  c:  d:  +次数//创建TreeMap对象 (需要可排序)String str="aababcabcdabcde";TreeMap<Character,Integer> tm=new TreeMap<Character,Integer>(new Comparator<Character>() {@Overridepublic int compare(Character o1, Character o2) {//从小到达排序 a b c dreturn o1-o2;}});//统计次数 循坏覆盖for(int i=0;i<str.length();i++){char c=str.charAt(i);if(tm.get(c)!=null){int number=tm.get(c);number++;tm.put(c,number);}else tm.put(c,1);}//遍历打印输出//获取每个键值对对象存入Set集合中Set<Map.Entry<Character,Integer>> entries=tm.entrySet();//构建迭代器对象Iterator<Map.Entry<Character,Integer>> it=entries.iterator();//迭代器遍历while(it.hasNext()){char key=it.next().getKey();int value=tm.get(key);System.out.print(key+"("+value+")"+" ");}//a(5) b(4) c(3) d(2) e(1)System.out.println();//lambda表达式遍历tm.forEach((character,integer)-> System.out.print(character+"("+integer+")"+" "));//a(5) b(4) c(3) d(2) e(1)System.out.println();//要求输出为字符串格式:StringBuilder sb=new StringBuilder();tm.forEach((character,integer)-> sb.append(character).append("(").append(integer).append(")").append(" "));System.out.println(sb);//a(5) b(4) c(3) d(2) e(1)//构建StringJoiner对象时括号内指定 开始标记、结束标记、中间间隔符号StringJoiner sj=new StringJoiner("","","");//add方法内参数需要是字符串,因此加上一个“” 使其转为字符串tm.forEach((character,integer)-> sj.add(character+"").add("(").add(integer+"").add(")").add(" "));System.out.println(sj);//a(5) b(4) c(3) d(2) e(1)}
}

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

w046基于web的古典舞在线交流平台的设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

【迅为】瑞芯微-RK3568开发板Linux+HAL启动测试

迅为iTOP&#xff0d;RK3568开发板AMP AMP SDK支持Rockchip平台异构多系统AMP&#xff08;非对称多核架构&#xff09;的开发软件包&#xff0c;支持Linux(Kernel)、Standalone(Hal)、RTOS(RT-Thread)组合AMP构建形式。可以满足一些特定行业应用&#xff0c;如电力物联网、电…

渗透测试--Windows系统下的文件传输手段

很多情况下&#xff0c;我们渗透测试都面临需要上传和下载文件的文件传输需求。本文专门探讨Windows服务器或主机上实施文件传输的各种方案。该专题比较敏感&#xff0c;该文章仅供学习使用&#xff0c;不要用于非法用途。 编码方法 Linux检查文件MD5 md5sum id_rsa Linux编…

视觉常用Backbone大全:VisionTransformer(ViT)

视觉常用Backbone大全 今天介绍的主干网络模型叫VisionTransformer&#xff0c;是一种将 Transformer 架构应用于计算机视觉任务的模型&#xff0c;通过将图像进行切块&#xff0c;将图片转变为self-attention认识的token输入到Transformer模块中&#xff0c;实现了Transformer…

星海智算:Stable Diffusion3.5镜像教程

Stable Diffusion3.5 模型介绍 Stable Diffusion 3.5是由Stability AI推出的最新图像生成模型&#xff0c;它是Stable Diffusion系列中的一个重大升级。这个模型家族包括三个版本&#xff0c;分别是Stable Diffusion 3.5 Large、Stable Diffusion 3.5 Large Turbo和Stable Dif…

[JavaWeb] 尚硅谷JavaWeb课程笔记

1 Tomcat服务器 Tomcat目录结构 bin&#xff1a;该目录下存放的是二进制可执行文件&#xff0c;如果是安装版&#xff0c;那么这个目录下会有两个exe文件&#xff1a;tomcat10.exe、tomcat10w.exe&#xff0c;前者是在控制台下启动Tomcat&#xff0c;后者是弹出GUI窗口启动To…

【Unity基础】认识Unity中的包

Unity中的包是一个核心概念&#xff0c;像Unity本身的功能的扩展&#xff0c;或者项目中资源的管理&#xff0c;都是通过包的形式来实现的。 一、什么是包&#xff1f; 一个包包含满足您项目各种需求的功能。这可以包括编辑器安装过程中附带的任何核心Unity功能&#xff0c;也…

elment-ui的折叠tree表单实现纯前端搜索,展开收起功能

好久没更新博客了~ 记录一下本次做的一个很扯的需求 纯前端去实现这个查询的功能,后台返回的是个数组对象,前端要给他包装成树结构先展示 之后参考代码路径src\views\goods\category\index.vue 需求描述: 搜索输入任何一个关键字,都会展开他的父级,两个栏目都包含了,那么两个父…

linux先创建文件夹后指定创建文件夹用户

1、创建文件夹&#xff0c;然后创建用户并指定用户目录&#xff0c;然后修改目录所有权给该目录 # 创建 /home/test 目录 mkdir /home/test # 设置权限&#xff08;确保有适当的读写权限&#xff09; chown root:root /home/test chmod 700 /home/test # 创建 xl 用户并指定家…

大模型(LLM)全参数微调有哪些技巧,常用的轻量级微调有哪些,微调策略应该如何选择?

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下大模型(LLM)全参数微调有哪些技巧&#xff0c;常用的轻量级微调有哪些&#xff0c;微调策略应该如何选择&#xff1f;本文将从大模型(LLM)全参数微调技巧&#xff0c;常用的轻量级微调方法&#xff0c;微调策略应该…

蓝牙电话-如何自动切换手机SIM卡(预研方向)

蓝牙电话-如何自动切换手机SIM卡&#xff08;预研方向&#xff09; 一、前言 最近突然有客户问说&#xff0c;蓝牙电话的app既然已经能统计手机里面插了多少张卡&#xff0c;那能不能做双卡的SIM卡自动切换&#xff1f;即&#xff1a;设置一个呼叫策略和频率&#xff0c;当打…

【蓝桥杯C/C++】C语言和C++的常量概念与区别分析

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: 蓝桥杯C/C 文章目录 &#x1f4af;前言&#x1f4af;常量的概念和作用&#x1f4af;C语言中 const 的应用与限制#define 和 enum 的使用方法 &#x1f4af;C 中 const 的计算方法和处理&#x1f4af;代码实例和应用区别&#x1f…

全面解析亚马逊云服务器(AWS):功能、优势与使用指南

亚马逊云服务器&#xff08;AWS&#xff09;概述 亚马逊云服务器&#xff08;Amazon Web Services&#xff0c;简称AWS&#xff09;是全球领先的云计算平台&#xff0c;提供一系列强大且灵活的云服务&#xff0c;帮助企业和开发者通过云基础设施实现数据存储、计算、分析和机器…

“小浣熊家族AI办公助手”产品体验 — “人人都是数据分析师”

一、引言&#xff1a; 大家平时应该在工作中常常使用到Excel来做数据统计&#xff0c;比如临近过年时&#xff0c;公司一般会开各种复盘、年终、检讨、明年规划大会&#xff0c;势必需要准备一大堆的量化数据报表&#xff0c;用于会议上的数据汇报、分析工作&#xff0c;试想一…

C盘扩容(C盘右键无法扩展卷解决)超详细步骤!!!

目录 1、问题及需求2、解决办法方法2 1、问题及需求 今天一看C盘爆红了&#xff0c;但是D盘还剩很多空间&#xff0c;想要从D盘再分出来50G给C盘。 但是压缩了D盘&#xff0c;在C盘扩展卷&#xff0c;实现不了&#xff0c;因为不仅挨着。看下边的解决办法 2、解决办法 桌面上…

机器学习笔记 // 天气预报、股票价格以及历史轨迹(如摩尔定律)// 时间序列的常见属性

时间序列随处可见。你可能已经在天气预报、股票价格以及历史轨迹[如摩尔定律&#xff0c;见下图​]等事物中见过它们。摩尔定律预测微芯片上面的晶体管个数大约每两年会翻倍。几乎50年以来&#xff0c;它已经被证明对未来的计算能源和成本来说是一个准确的预测器。 许多时间序列…

mysql日志写满出现The table ‘xxxx_amazon_order’ is full

数仓发现写数据出现 SQL 错误 [1114] [HY000]: The table ‘xxxx_amazon_order’ is full 1.第一时间查看系统磁盘, 发现空间写满了 df -h因为mysql是使用docker部署的, Docker 的默认存储位置在 /var/lib/docker /var 目录默认是在根分区 (/dev/mapper/centos-root) 下的 …

(一)Ubuntu22.04服务器端部署Stable-Diffusion-webui AI绘画环境

一、说明 cup型号&#xff1a; Intel(R) Celeron(R) CPU G1610 2.60GHz 内存大小&#xff1a; 8G 显卡型号&#xff1a;NVIDIA P104-100 注意&#xff1a;系统睡眠问题 sudo systemctl mask sleep.target suspend.target hibernate.target hybrid-sleep.target 网卡设置 …

springboot:少量配置信息情形

发现无论怎么改都还是指向8001 所以换一种方法 通过 结果 代码 import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.web.server.ConfigurableWebServerFactory; import org.springframework.boot.web.server.WebServerFactoryCusto…

SpringBoot的快速入门

Maven Maven可以方便管理依赖的 Jar 包 IDEA 自带Maven&#xff0c;也可以选择自己安装 安装Maven:https://blog.csdn.net/qq_59636442/article/details/142314019 创建项目 通过Spring Initializr 快速创建项目&#xff1a;https://start.springboot.io/ 我的项目名叫blog&a…