百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

想月薪过万吗?计算机安卓开发之"集合"

wptr33 2025-07-19 23:05 5 浏览

集合的总结:

/**

* Collection

* List(存取有序,有索引,可以重复)

* ArrayList

* 底层是数组实现的,线程不安全,查找和修改快,增和删比较慢

* LinkedList

* 底层是链表实现的,线程不安全,增和删比较快,查找和修改比较慢

* Vector

* 底层是数组实现的,线程安全的,无论增删改查都慢

* 如果查找和修改多,用ArrayList

* 如果增和删多,用LinkedList

* 如果都多,用ArrayList

* Set(存取无序,无索引,不可以重复)

* HashSet

* 底层是哈希算法实现

* LinkedHashSet

* 底层是链表实现,但是也是可以保证元素唯一,和HashSet原理一样

* TreeSet

* 底层是二叉树算法实现

* 一般在开发的时候不需要对存储的元素排序,所以在开发的时候大多用HashSet,HashSet的效率比较高

* TreeSet在面试的时候比较多,问你有几种排序方式,和几种排序方式的区别

* Map

* HashMap

* 底层是哈希算法,针对键

* LinkedHashMap

* 底层是链表,针对键

* TreeMap

* 底层是二叉树算法,针对键

* 开发中用HashMap比较多

*/

集合代码实现斗地主的功能:

  1. package com.123.test;

  2. import java.util.ArrayList;

  3. import java.util.Collections;

  4. import java.util.HashMap;

  5. import java.util.TreeSet;

  6. publicclassTest3{

  7. /**

  8. * * A:案例演示

  9. * 模拟斗地主洗牌和发牌并对牌进行排序的代码实现

  10. *

  11. * 分析:

  12. * 1,买一副扑克,其实就是自己创建一个集合对象,将扑克牌存储进去

  13. * 2,洗牌

  14. * 3,发牌

  15. * 4,看牌

  16. */

  17. publicstaticvoid main(String[] args){

  18. //1,买一副扑克,其实就是自己创建一个集合对象,将扑克牌存储进去

  19. String[] num ={"3","4","5","6","7","8","9","10","J","Q","K","A","2"};

  20. String[] color ={"红桃","黑桃","方片","梅花"};

  21. HashMap<Integer,String> hm =newHashMap<>();//存储索引和扑克牌

  22. ArrayList<Integer> list =newArrayList<>();//存储索引

  23. int index =0;

  24. //拼接扑克牌并索引和扑克牌存储在hm中

  25. for(String s1 : num){//获取数字

  26. for(String s2 : color){//获取颜色

  27. hm.put(index, s2.concat(s1));

  28. list.add(index);//将索引0到51添加到list集合中

  29. index++;

  30. }

  31. }

  32. //将小王添加到双列集合中

  33. hm.put(index,"小王");

  34. list.add(index);//将52索引添加到集合中

  35. index++;

  36. hm.put(index,"大王");

  37. list.add(index);//将52索引添加到集合中

  38. //2,洗牌

  39. Collections.shuffle(list);

  40. //3,发牌

  41. TreeSet<Integer> gaojin =newTreeSet<>();

  42. TreeSet<Integer> longwu =newTreeSet<>();

  43. TreeSet<Integer> me =newTreeSet<>();

  44. TreeSet<Integer> dipai =newTreeSet<>();

  45. for(int i =0; i < list.size(); i++){

  46. if(i >= list.size()-3){

  47. dipai.add(list.get(i));//将三张底牌存储在底牌集合中

  48. }elseif(i %3==0){

  49. gaojin.add(list.get(i));

  50. }elseif(i %3==1){

  51. longwu.add(list.get(i));

  52. }else{

  53. me.add(list.get(i));

  54. }

  55. }

  56. //看牌

  57. lookPoker(hm, gaojin,"高进");

  58. lookPoker(hm, longwu,"龙五");

  59. lookPoker(hm, me,"冯佳");

  60. lookPoker(hm, dipai,"底牌");

  61. }

  62. /*

  63. * 看牌

  64. * 1,返回值类型void

  65. * 2,参数列表HashMap,TreeSet,String name

  66. */

  67. publicstaticvoid lookPoker(HashMap<Integer,String> hm,TreeSet<Integer> ts ,String name){

  68. System.out.print(name +"的牌是:");

  69. for(Integer i : ts){//i代表双列集合中的每一个键

  70. System.out.print(hm.get(i)+" ");

  71. }

  72. System.out.println();

  73. }

  74. }

相关推荐

面试官:MySQL的自增ID用完了,怎么办?

来自:Java技术驿站既然这块知识点不清楚,那回头就自己动手实践下。首先,创建一个最简单的表,只包含一个自增id,并插入一条数据。create table t0(id i...

SQL 开发必学:深度解析 NULL 值处理的 6 大核心规则与避坑指南

在数据库开发中,NULL值处理是极易引发逻辑错误的技术难点。本文从SQL标准规范出发,系统梳理NULL值的底层逻辑与工程实践要点,帮助开发者建立完整的NULL值处理知识体系。一、三值逻辑...

SQL查找是否&quot;存在&quot;,别再用count了

根据某一条件从数据库表中查询『有』与『没有』,只有两种状态,那为什么在写SQL的时候,还要SELECTCOUNT(*)呢?无论是刚入道的程序员新星,还是精湛沙场多年的程序员老白,都是一如既往...

一文带你掌握shell脚本中的if条件语句,轻松搞定工作需求

#shell编程##linux#...

一文搞懂MySQL的左、右、内、外连接

一、前言1、MySQL中的左连接...

性能测试:Mysql中的空值陷阱(mysql中空值怎么表示)

SQL是一种声明式的语言,我们只需要描述想要的结果(WHAT),而不关心数据库如何实现(HOW);虽然SQL比较容易学习,但是仍然有一些容易混淆和出错的概念。今天我们就来说说SQL中的空值陷阱...

MySQL--常用函数(MySQL常用函数汇总)

介绍MySQL函数,是一种控制流程函数,属于数据库用语言。MySQL数据库中提供了很丰富的函数。MySQL函数包括数学函数、字符串函数、日期和时间函数、条件判断函数、系统信息函数、加密函数、格式化函数...

MySQL函数详解:IF()、IFNULL()、NULLIF()、ISNULL()、CASE

2025年3月27日,MySQL作为最流行的关系型数据库管理系统之一,其丰富的函数库为开发者提供了强大的数据处理能力。本文将详细解析MySQL中常用的条件判断函数:IF()、IFNULL()、NULL...

java迭代器iterator(java迭代器iterator增加一条记录)

/***iterator迭代器Collection接口继承了Iterable接口iterable可迭代的在Iterable接口中定义了iterator()方法用于生成迭代器...

说说Redis的数据类型(redis中的数据类型)

一句话总结Redis核心数据类型包括:String:存储文本、数字或二进制数据。List:双向链表,支持队列和栈操作。Hash:字段-值映射,适合存储对象。Set:无序唯一集合,支持交并差运算。...

一网打尽-HashMap面试题(hashmap数据结构面试)

全文4896字。读完五分钟,即可获得HashMap理解全部面经和原理。坚持就是胜利1、实现原理...

本地缓存GuavaCache(一)(本地缓存caffeine)

在并发量、吞吐量越来越大的情况下往往是离不开缓存的,使用缓存能减轻数据库的压力,临时存储数据。根据不同的场景选择不同的缓存,分布式缓存有Redis,Memcached、Tair、EVCache、Aer...

想月薪过万吗?计算机安卓开发之&quot;集合&quot;

集合的总结:/***Collection*List(存取有序,有索引,可以重复)*ArrayList*底层是数组实现的,线程不安全,查找和修改快,增和删比较慢...

Spring Boot 控制 Controller 接口的4种方式,哪种更适合你?

环境:SpringBoot3.4.2...

这些Java基础知识,诸佬们都还记得嘛(学习,复习,面试均可)

方法重载和方法重写的区别方法重写重写体现在继承关系上。在Java中,子类继承父类,子类就会具备父类所以的特征,以及父类的方法和变量比如动物类有“叫”的方法,小狗小猫分别继承了动物类,重写方法时就可以...