当前位置: 首页 > wzjs >正文

前端做网站直播旺道seo系统

前端做网站直播,旺道seo系统,权威的网站建设,影视网站模板HashMap 说明 HashMap是Map里面的一个实现类。 没有额外需要学习的特有方法,直接使用继承自Map里面的方法就可以了。 特点 特点都是由键决定的:无序、不重复、无索引 HashMap的底层原理 HashMap跟HashSet底层原理是一模一样的,都是哈希表结构…

HashMap

说明

HashMap是Map里面的一个实现类。
没有额外需要学习的特有方法,直接使用继承自Map里面的方法就可以了。

特点

特点都是由键决定的:无序、不重复、无索引

HashMap的底层原理

HashMap跟HashSet底层原理是一模一样的,都是哈希表结构

利用键计算哈希值,和值无关

集合中存入的元素时会先将键和值封装为键值对(Entry)类,再将Entry类存入集合

注意事项

HashMap底层依赖hashCode方法和equals方法保证键的唯一
如果键存储的是自定义对象,需要重写hashCode和equals方法
如果值存储自定义对象,不需要重写hashCode和equals方法 

案例练习

存储学生对象并遍历

创建一个HashMap集合,键是学生对象(Student),值是籍贯(String)。
存储三个键值对元素,并遍历
要求:同姓名,同年龄认为是同一个学生

Student类

import java.util.Objects;public class Student {private String name;private int age;public Student() {}public Student(String name, int age) {this.name = name;this.age = age;}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;}//键是自定义对象,需要重写equals和hashCode方法//才能通过比较自定义对象的属性值判断是否唯一@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);}@Overridepublic int hashCode() {return Objects.hash(name, age);}@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +", age=" + age +'}';}
}

测试类 

import java.util.HashMap;public class Test {public static void main(String[] args) {HashMap<Student, String> hm = new HashMap<>();Student s1 = new Student("zhangsan", 23);Student s2 = new Student("lisi", 24);Student s3 = new Student("wangwu", 25);hm.put(s1, "北京");hm.put(s2, "上海");hm.put(s3, "深圳");hm.forEach((student, s) -> System.out.println(student + " = " + s));//Student{name='wangwu', age=25} = 深圳//Student{name='lisi', age=24} = 上海//Student{name='zhangsan', age=23} = 北京//s4的键与s1重复,覆盖s1的值Student s4 = new Student("zhangsan", 23);hm.put(s4, "重庆");hm.forEach((student, s) -> System.out.println(student + " = " + s));//Student{name='wangwu', age=25} = 深圳//Student{name='lisi', age=24} = 上海//Student{name='zhangsan', age=23} = 重庆}
}
统计投票人数

某个班级80名学生,现在需要组成秋游活动,班长提供了四个景点依次是(A、B、C、D),每个学生只能选择一个景点,请统计出最终哪个景点想去的人数最多。

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Random;
import java.util.Set;public class Test1 {public static void main(String[] args) {//定义数组记录选项char[] ch = {'A', 'B', 'C', 'D'};//定义集合记录投票结果ArrayList<Character> list = new ArrayList<>();//模拟投票,将结果存入集合Random r = new Random();for (int i = 0; i < 80; i++) {int index = r.nextInt(ch.length);char c = ch[index];list.add(c);}//定义双列集合,键是选项,值是该选项的被投次数HashMap<Character, Integer> hm = new HashMap<>();//遍历集合list中的每一个选项,判断集合hm的键是否存在该选项//如果不存在就将该选项存入hm为键,值为1//如果存在就将该选项对应的值加1for (char c : list) {if (hm.containsKey(c)) {//存在int count = hm.get(c);count++;hm.put(c, count);} else {//不存在hm.put(c, 1);}}//得到最高票数int max = 0;Set<Character> chs = hm.keySet();for (char c : chs) {int count = hm.get(c);if (count > max) {max = count;}}System.out.println(hm);//{A=23, B=14, C=15, D=28}//判断哪一个选项对应的票数是最高票for (char c : chs) {int count = hm.get(c);if (count == max) {System.out.println(c);//D}}}
}

LinkedHashMap

特点

由键决定:有序、不重复、无索引
这里的有序指的是保证存储和取出的元素顺序一致

LinkedHashMap的底层原理

底层数据结构依然是哈希表,只是每个键值对元素又额外的多了一个双链表的机制记录存储的顺序

TreeMap

特点

由键决定特性:可排序、不重复、无索引
可排序:对键进行排序

TreeMap底层原理

TreeMap跟TreeSet底层原理一样,都是红黑树结构

两种排序规则

实现Comparable接口,指定比较规则。
创建集合时传递Comparator比较器对象,指定比较规则。 

案例练习

需求1

键:整数表示id
值:字符串表示商品名称
要求:按照id的升序排列、按照id的降序排列

import java.util.TreeMap;public class Test2 {public static void main(String[] args) {//默认升序排列TreeMap<Integer, String> tm1 = new TreeMap<>();tm1.put(2, "苹果");tm1.put(3, "香蕉");tm1.put(1, "橘子");tm1.put(4, "梨子");System.out.println(tm1);//{1=橘子, 2=苹果, 3=香蕉, 4=梨子}//传递Comparator比较器对象,实现降序排列TreeMap<Integer, String> tm2 = new TreeMap<>((o1, o2) -> o2 - o1);tm2.put(2, "苹果");tm2.put(3, "香蕉");tm2.put(1, "橘子");tm2.put(4, "梨子");System.out.println(tm2);//{4=梨子, 3=香蕉, 2=苹果, 1=橘子}}
}
需求2

键:学生对象
值:籍贯
要求:按照学生年龄的升序排列,年龄一样按照姓名的字母排列,同姓名年龄视为同一个人 

Student类 

public class Student implements Comparable<Student> {private String name;private int age;public Student() {}public Student(String name, int age) {this.name = name;this.age = age;}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;}@Overridepublic String toString() {return "Student{" +"name='" + name + '\'' +", age=" + age +'}';}@Overridepublic int compareTo(Student o) {//按照学生年龄的升序排列,年龄一样按照姓名的字母排列,同姓名年龄视为同一个人int i = this.getAge() - o.getAge();i = i == 0 ? this.getName().compareTo(o.getName()) : i;return i;}
}

 测试类

import java.util.TreeMap;public class Test {public static void main(String[] args) {TreeMap<Student, String> tm = new TreeMap<>();Student s1 = new Student("zhangsan", 23);Student s2 = new Student("lisi", 24);Student s3 = new Student("wangwu", 25);tm.put(s2, "上海");tm.put(s3, "深圳");tm.put(s1, "北京");tm.forEach((student, s) -> System.out.println(student + " = " + s));//Student{name='zhangsan', age=23} = 北京//Student{name='lisi', age=24} = 上海//Student{name='wangwu', age=25} = 深圳Student s4 = new Student("zhangsan", 23);tm.put(s4, "重庆");tm.forEach((student, s) -> System.out.println(student + " = " + s));//Student{name='zhangsan', age=23} = 重庆//Student{name='lisi', age=24} = 上海//Student{name='wangwu', age=25} = 深圳}
}

http://www.dtcms.com/wzjs/501880.html

相关文章:

  • 网上找兼职的网站百度电脑版入口
  • 个旧市城乡建设局网站关键词推广排名软件
  • 政府网站建设背景今日财经新闻
  • wordpress设置手机浏览器营销型网站优化
  • 如何给wordpress添加一张网站背景免费做网站网站
  • 用php做购物网站案例十八未成年禁用免费app
  • 关于网站建设申请seo网络搜索引擎优化
  • wap网站如何做兰州seo培训
  • 全屏网站模板制作最近三天的新闻大事国内
  • 最牛的网站建设公众号排名优化软件
  • 腾讯云可以用wordpress教程学好seo
  • 淘宝客怎么做网站导购免费网站模板网
  • 哈尔滨网站建设设计项目推广渠道有哪些
  • 杭州建站模板系统qq营销推广方法和手段
  • 宁波公司网站开发招聘seo关键词排名软件流量词
  • 加拿大计划网站怎么做论坛seo招聘
  • 高端网站优化广州seo网站推广公司
  • 怎么做网站dns加速排名点击软件怎样
  • 保定哪家做网站好长尾关键词挖掘精灵官网
  • 徐州 网站制作晨阳seo
  • 苏州建设工程人才招聘网信息网站windows优化大师要钱
  • 网站制作学校要的重庆网站制作公司
  • 什么后台做网站安全河南网站顾问
  • wordpress 图片保护关键词优化公司排名榜
  • 敏感网站用什么浏览器淘宝流量
  • 怎么样做网站爬虫樱桃bt官网
  • 成都学校网站制作武汉最新消息今天
  • 四川省建设工程招标网官网专业优化网站排名
  • 政府网站建设工作的自查报告哪里有免费的网站推广服务
  • 做课展网站seo是什么意思电商