扑克牌小游戏:
游戏玩法简介:定义五个People在玩扑克牌游戏,玩法是5个人从一副没有大小王的扑克牌中各抽取4张,牌的类型有四种:,,,。牌的大小为从1~13。(此处为了简单,只取1 -5).
1.黑桃A在哪名玩家手中,哪名玩家就获胜。
package poker;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;
import java.util.concurrent.Callable;
public class Game {
public static void main(String[] args) {
//定义5名玩家,使用List
List<Player> playerList=new ArrayList<>();
playerList.add(new Player("于美人"));
playerList.add(new Player("小婷子"));
playerList.add(new Player("小晨子"));
playerList.add(new Player("小艾"));
playerList.add(new Player("小珍子"));
//定义扑克牌顺序表
List<Card> cardList=new ArrayList<>();
//初始化扑克牌
initializeCards(cardList);
System.out.println(cardList);
//调用collections下的shuffle(洗牌)方法
//进行洗牌
Collections.shuffle(cardList);
//System.out.println("抽牌前,牌组中的牌:");
System.out.println(cardList);
//发牌
int n=2;//每名玩家发几张牌
for(int i=0;i<n;i++){
//一共发n轮牌
for(Player player:playerList){
//每名玩家一次抽牌
Card card=cardList.remove(0);//从牌组中,抽一张牌出来
player.cardList.add(card);//把这张牌放到当前玩家的手中
}
}
System.out.println("现在牌组中剩余的牌:");
System.out.println(cardList);
System.out.println("交换牌之前:");
for(Player player:playerList){
System.out.printf("玩家[%s]的手牌是: %s%n",player.name,player.cardList);
}
//要找的牌,方法1
Card toFoundCard=new Card("",1);
for(Player player:playerList){
for(Card card:player.cardList){
//比较每张牌和要找的是否为同一张牌
if(card.equals(toFoundCard)){
System.out.println(player.name+"获胜");
return;
}
}
}
System.out.println("无人获胜");
}
//要找的牌,方法2
Card toFoundCard2=new Card("",1);
for(Player player:playerList){
if(player.cardList.contains(toFoundCard)) {
System.out.println(player.name + "获胜");
return;
}
}
private static void initializeCards(List<Card> cards){
for(String suit:new String[]{
"","","",""}){
for(int rank=1;rank<=5;rank++){
Card card=new Card(suit,rank);
//把扑克牌放入牌组中
cards.add(card);
}
}
}
2.让每名玩家,依次抽取他的下家的一张手牌,然后再找A,找到A就获胜。
//添加打印手牌的方法
public static void printPlayerHandCard(List<Player> playerList){
for(Player player:playerList){
System.out.printf("玩家[%s]的手牌是:%s%n",player.name,player.cardList);
}
}
//集体实现交换的过程
//交换牌
//每名玩家随机抽取下家的一张牌
Random random=new Random();
for(int i=0;i<playerList.size();i++){
Player currentPlayer=playerList.get(i);
//下家就是按照前后关系的下一个,最后一名玩家抽取第0个
Player nextPlayer=playerList.get(i!=playerList.size()-1?i+1:0);
//要取的牌的下标
int toDrawIndex=random.nextInt(nextPlayer.cardList.size());
//取牌
Card drawCard=nextPlayer.cardList.remove(toDrawIndex);
//放入当前玩家的手中
currentPlayer.cardList.add(drawCard);
}
System.out.println("交换牌之后:");
printPlayerHandCard(playerList);
3.于美人是赌神,她有变牌能力:她手中一旦没有A,她就可以把第一张牌变成A。(交换牌之前,有机会变一次;交换牌之后,有机会变一次)
Card toFoundCard=new Card("",1);
//已知于美人的下标为0
Player 于美人=playerList.get(0);
if(!于美人.cardList.contains(toFoundCard)){
于美人.cardList.set(0,toFoundCard);
}
System.out.println("于美人第一次发功:");
printPlayerHandCard(playerList);
System.out.println("交换牌之后:");
printPlayerHandCard(playerList);
//此处交换牌过程省略。。。。。。。。。。。。。。
if(!于美人.cardList.contains(toFoundCard)){
于美人.cardList.set(0,toFoundCard);
}
System.out.println("于美人第二次发功:");
printPlayerHandCard(playerList);
定义玩家新的的一个类:
package poker;
import java.util.ArrayList;
import java.util.List;
public class Player {
public List<Card> cardList=new ArrayList<>();
public String name;
public Player(String name){
this.name=name;
}
}
定义扑克牌的一个类:
package poker;
import java.util.Objects;
public class Card {
public String suit;//花色
public int rank;//分值
//构造方法
public Card(String suit,int rank){
this.rank=rank;
this.suit =suit;
}
@Override
public String toString() {
return String.format("[%s%d]",suit,rank);
}
//重写比较相等的方法
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Card card = (Card) o;
return rank == card.rank &&
Objects.equals(suit, card.suit);
}
}
注意:(1)要重新定义比较相等方法的重写。
(2)注意foreach 方法的写法。
文章浏览阅读86次。首发地址:https://yq.aliyun.com/articles/221708谈到机器学习,相信很多除学者都是通过斯坦福大学吴恩达老师的公开课《Machine Learning》开始具体的接触机器学习这个领域,但是学完之后又不知道自己的掌握情况,缺少一些实际的项目操作。对于机器学习的相关竞赛挑战,有些项目的门槛有些高,参加后难以具体的实现,因此造..._scrath五子棋下载
文章浏览阅读83次。原标题:Oracle 12c新特性系列专题-安徽Oracle授权认证中心 随着Oracle database 12c的普及,数据库管理员 (DBA) 的角色也随之发生了转变。 Oracle 12c数据库对 DBA 而言是下一代数据管理。它让 DBA 可以摆脱单调的日常管理任务,能够专注于如何从数据中获取更多价值。未来我们会推出基于Oracle12c的技术文章,帮助DBA尽快掌握新一代数据库的新特性..._ilm add policy row store compress advanced row after
文章浏览阅读150次。问题及代码:*Copyright(c)2016,烟台大学计算机与控制工程学院 *All right reserved. *文件名称:负数把正数赶出队列.cpp *作者:张冰 *完成日期;2016年10月09日 *版本号;v1.0 * *问题描述: 设从键盘输入一整数序列a1,a2,…an,试编程实现: 当ai>0时,ai进队,当ai<0时,将队首元素出队,当ai
文章浏览阅读376次。贪心+构造
文章浏览阅读150次。本文讲的是Linux命名空间学习教程(二) IPC,【编者的话】Docker核心解决的问题是利用LXC来实现类似VM的功能,从而利用更加节省的硬件资源提供给用户更多的计算资源。而 LXC所实现的隔离性主要是来自内核的命名空间, 其中pid、net、ipc、mnt、uts 等命名空间将容器的进程、网络、消息、文件系统和hostname 隔离开。本文是Li..._主机的 ipc 命名空间
文章浏览阅读2w次,点赞5次,收藏7次。在设备上强制安装apk。在app已有的情况下使用-r参数在app版本低于现有版本使用-d参数命令adb install -r -d xxx.apk_adb绕过安装程序强制安装app
文章浏览阅读290次。如果是越界进入硬件错误中断,MSP 或者 PSP 保存错误地址,跳转前会保存上一次执行的地址,lr 寄存器会保存子函数的地址,所以如果在 HardFault_CallBack 中直接调用 C 语言函数接口会间接修改了 lr,为了解决这个问题,直接绕过 lr 的 C 语言代码,用汇编语言提取 lr 寄存器再决定后面的操作。由于 STM32 加入了 FreeRTOS 操作系统,可能导致无法准确定位,仅供参考(日常编程需要考虑程序的健壮性,特别是对数组的访问,非常容易出现越界的情况)。_stm32flash地址越界怎么解决
文章浏览阅读1.8k次。学到了一种操作,说实话,我从来没想过还能这样正常情况下,为了管理方便,许多管理员都会开放MySQL数据库的secure_file_priv,这时就可以导入或者导出数据当我如图输入时,就会在D盘创建一个名为123456.php,内容为<?php phpinfo();?>的文件我们可以利用这一点运用到SQL注入中,从拿下数据库到拿下目标的服务器比如我们在使用联合查询注入,正常是这样的语句http://xxx?id=-1 union select 1,'你想知道的字段的内容或查询语句',
文章浏览阅读2.9w次,点赞12次,收藏63次。感谢原文:https://blog.csdn.net/abc5382334/article/details/24260817感谢原文:https://blog.csdn.net/jiaqingge/article/details/52564348Html CSS的三种链接方式css文本的链接方式有三种:分别是内联定义、链入内部css、和链入外部css1.代码为:<html>..._html链接css代码
文章浏览阅读625次。近几年,蓝牙耳机市场发展迅速,越来越多的消费者希望抛弃线缆,更自由地听音乐,对于运动人士来说,蓝牙耳机的便携性显得尤为重要。但目前市面上的大多数蓝牙耳机实际上都是“有线”的,运动过程中产生的听诊器效应会严重影响听歌的感受。而在“真无线”耳机领域,除了苹果的AirPods外,可供选择的产品并不多,而AirPods又不是为运动场景打造的,防水能力非常差。那么对于喜欢运动又想要“自由”的朋友来说,有没有一款产品能够满足他们的需求呢?下面这十款小编专门为大家搜罗的蓝牙耳机或许就能找到适合的!网红击音F1_适合游戏与运动的高音质蓝牙耳机
文章浏览阅读1k次,点赞6次,收藏7次。在本篇博文中,我们在 iOS 17 beta 4(SwiftUI 5.0)测试版中发现了 SwiftUI 视图首次显示时状态的改变会导致动画“副作用”的问题,并提出多种解决方案。
文章浏览阅读1.9k次。 在 上篇文章–Flutter 实现支持上拉加载和下拉刷新的 ListView 中,我们最终实现的效果是在 listView 上面留下了一段空白,本意是用来加载轮播图的,于是今天就开发了一下,希望能给各位灵感。一 、效果如下说一下大体思路 其实图片展示是用的 PageView ,然后,下面的指示器 是用的 TabPageSelector ,当然整体是用 Stack 包裹起来的。1、..._flutter pageview轮播图 site:csdn.net