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

Java基础第9天总结(可变参数、Collections、斗地主)

  • 认识可变参数

package Demo;import java.util.Arrays;public class ParamDemo {//认识可变参数public static void main(String[] args) {sum();//不传参数sum(1);//传一个参数sum(1,2,3,4,5);//传多个参数sum(new int[]{1,2,3});//传一个数组参数}//注意事项:可变参数必须是最后一个参数,且只能有一个可变参数public static void sum(int...nums){System.out.println(nums.length);System.out.println(Arrays.toString(nums));System.out.println("-------------");}
}

输出:

0
[]
-------------
1
[1]
-------------
5
[1, 2, 3, 4, 5]
-------------
3
[1, 2, 3]
-------------



  • Collections
package Demo;import java.util.ArrayList;
import java.util.Collections;
import java.util.List;public class ParamDemo {public static void main(String[] args) {List<Integer> list = new ArrayList<>();//1、Collections的方法批量加Collections.addAll(list, 1,2,3,4,5);System.out.println(list);//2、打乱顺序Collections.shuffle(list);System.out.println(list);//3、排序Collections.sort(list);System.out.println(list);//4、自定义排序Collections.sort(list, (s1,s2)->Integer.compare(s2,s1));System.out.println(list);}
}

输出:

[1, 2, 3, 4, 5]
[3, 4, 5, 1, 2]
[1, 2, 3, 4, 5]
[5, 4, 3, 2, 1]



  • 斗地主游戏案例
package DouDiZhu;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;@Data
@NoArgsConstructor
@AllArgsConstructor
public class Card {private String size;private String color;private int num;//大小@Overridepublic String toString() {return size + color;}
}
package DouDiZhu;import java.util.*;public class Room {//1、准备好54张牌:定义一个容器装54张牌private List<Card> allcards = new ArrayList<>();//2、初始化54张牌进去{//3、准备点数String[] sizes = {"3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K", "A", "2"};//4、准备花色String[] colors = {"♠", "♥", "♣", "♦"};//5、组合点数和花色成为牌对象,加入到集合中int count=1;for(String size : sizes){for(String color : colors){//6、创建牌对象Card card = new Card(size, color, count++);//7、加入集合allcards.add(card);}}Collections.addAll(allcards, new Card("", "🃏", count++), new Card("", "👲", count));System.out.println("新牌是" + allcards);}public void start() {//8、洗牌:随机打乱集合中的顺序Collections.shuffle(allcards);System.out.println("洗牌后:" + allcards);//9、发牌:定义三个玩家:令狐冲=【】、令狐白=【】、令狐紫=【】Map<String,List< Card>> players = new HashMap<>();List< Card> lhc = new ArrayList<>();players.put("令狐冲", lhc);List< Card> lhb = new ArrayList<>();players.put("令狐白", lhb);List< Card> lhz = new ArrayList<>();players.put("令狐紫", lhz);for(int i = 0; i < allcards.size(); i++){Card card = allcards.get(i);if(i % 3 == 0){lhc.add(card);}else if(i % 3 == 1){lhb.add(card);}else{lhz.add(card);}}//10、拿最后三张底牌List<Card> lastCards = allcards.subList(allcards.size() - 3, allcards.size());System.out.println("底牌是:" + lastCards);//抢地主:把这个集合直接倒给玩家lhz.addAll(lastCards);//11、对牌排序sortCards(lhc);sortCards(lhb);sortCards(lhz);//12、看牌Set<Map.Entry<String, List<Card>>> entries = players.entrySet();for(Map.Entry<String, List<Card>> entry : entries){String name = entry.getKey();List<Card> cards = entry.getValue();System.out.println(name + "的牌是:" + cards);}}private void sortCards(List<Card> cards) {Collections.sort(cards, (c1,c2)->Integer.compare(c2.getNum(),c1.getNum()));//Collections.sort(cards, (c1,c2)->{return c2.getNum()-c1.getNum();});等价}
}
package DouDiZhu;public class Game {public static void main(String[] args) {Room r = new Room();r.start();}
}
输出:
新牌是[3♠, 3♥, 3♣, 3♦, 4♠, 4♥, 4♣, 4♦, 5♠, 5♥, 5♣, 5♦, 6♠, 6♥, 6♣, 6♦, 7♠, 7♥, 7♣, 7♦, 8♠, 8♥, 8♣, 8♦, 9♠, 9♥, 9♣, 9♦, 10♠, 10♥, 10♣, 10♦, J♠, J♥, J♣, J♦, Q♠, Q♥, Q♣, Q♦, K♠, K♥, K♣, K♦, A♠, A♥, A♣, A♦, 2♠, 2♥, 2♣, 2♦, 🃏, 👲]
洗牌后:[10♣, 3♠, 4♣, 10♦, A♣, 7♠, 8♣, Q♥, 7♥, 8♠, 8♥, 6♠, 2♣, 3♣, 5♥, 6♥, K♣, 2♥, A♦, 9♠, J♣, 9♦, 3♦, 👲, K♦, 5♠, K♠, 7♣, 🃏, A♠, J♠, 10♥, Q♠, 8♦, 2♦, 9♥, 6♣, 5♦, J♦, J♥, 7♦, Q♦, 5♣, 4♥, 4♦, 2♠, A♥, 9♣, 4♠, K♥, Q♣, 6♦, 10♠, 3♥]
底牌是:[6♦, 10♠, 3♥]
令狐冲的牌是:[2♣, 2♠, A♦, K♦, J♥, J♠, 10♦, 10♣, 9♦, 8♦, 8♣, 8♠, 7♣, 6♦, 6♣, 6♥, 5♣, 4♠]
令狐白的牌是:[🃏, 2♦, A♣, A♥, K♣, K♥, Q♥, 10♥, 10♠, 9♠, 8♥, 7♦, 5♦, 5♠, 4♥, 3♦, 3♣, 3♠]
令狐紫的牌是:[👲, 2♥, A♠, K♠, Q♦, Q♣, Q♠, J♦, J♣, 10♠, 9♣, 9♥, 7♥, 7♠, 6♦, 6♠, 5♥, 4♦, 4♣, 3♥, 3♥]

http://www.xdnf.cn/news/19686.html

相关文章:

  • 魔域服务器多少钱一个月?魔域服务器配置要求及推荐
  • Linux 入门到精通,真的不用背命令!零基础小白靠「场景化学习法」,3 个月拿下运维 offer,第二十四天
  • 鸿蒙Next开发指南:XComponent与Progress组件的深度解析与实践
  • 在 PySpark 中解锁窗口函数的力量,实现高级数据转换
  • 数控机床相邻轨迹最大过渡速度计算方法介绍
  • 【Kubernetes】知识点2
  • 【数学建模学习笔记】时间序列分析:LSTM
  • Vue 3 + TypeScript 现代前端开发最佳实践(2025版指南)
  • 【完整源码+数据集+部署教程】PHC桩实例分割系统源码和数据集:改进yolo11-Faster-EMA
  • 黄金金融期货数据API对接技术文档
  • nmap扫描端口,netstat
  • 土地退化相关
  • Axure: 平滑折线图
  • Apache Doris:重塑湖仓一体架构的高效计算引擎
  • 文件页的预取逻辑
  • 小兔鲜儿项目
  • 树莓派网页监控
  • 从 Arm Compiler 5 迁移到 Arm Compiler 6
  • 2025 随身 WIFI 行业报告:从拼参数到重体验,华为 / 格行 / 中兴技术差异化路径解析
  • 梳理一下 @types/xxx
  • java面试中经常会问到的多线程问题有哪些(基础版)
  • think
  • ubuntu系统设置中文失败问题
  • grpc-swift-2 学习笔记
  • 均匀分布直线阵的常规波束形成方位谱和波束图
  • (Arxiv-2025)ConceptMaster:基于扩散 Transformer 模型的多概念视频定制,无需测试时微调
  • 【2025终极对决】Python三大后端框架Django vs FastAPI vs Robyn,你的选择将决定项目生死?
  • [光学原理与应用-366]:ZEMAX - 用成像原理说明人眼为什么能看清物体?
  • 两款超实用办公插件推荐:Excel聚光灯与Word公文排版
  • MySQL 多表查询方法