用Java写一个21点小游戏并且解释代码

时间: 2024-01-25 10:05:07 浏览: 26
好的,我来为您解答。 21点游戏,也叫黑杰克,是一种非常经典的纸牌游戏。玩家需要通过抽牌的方式,让自己的牌点数尽量接近21点,但不能超过21点。其中,A牌可以看成1或11点,J、Q、K牌都算10点,其他牌按照牌面点数算。下面是用Java写的21点小游戏代码: ```java import java.util.Scanner; public class BlackJack { public static void main(String[] args) { Scanner input = new Scanner(System.in); int playerScore = 0; // 玩家得分 int dealerScore = 0; // 庄家得分 // 初始状态,玩家和庄家各发两张牌 for (int i = 0; i < 2; i++) { playerScore += drawCard(); dealerScore += drawCard(); } // 玩家开始抽牌 while (true) { System.out.println("你的得分是:" + playerScore); // 判断是否爆掉 if (playerScore > 21) { System.out.println("你爆了,游戏结束!"); break; } // 询问玩家是否继续抽牌 System.out.print("是否抽牌?(Y/N) "); String choice = input.nextLine(); if (choice.equalsIgnoreCase("Y")) { playerScore += drawCard(); } else if (choice.equalsIgnoreCase("N")) { break; } } // 庄家开始抽牌 while (dealerScore < 17) { System.out.println("庄家得分是:" + dealerScore); dealerScore += drawCard(); } // 判断输赢 if (dealerScore > 21) { System.out.println("庄家爆了,你赢了!"); } else if (playerScore > dealerScore) { System.out.println("你的得分是:" + playerScore); System.out.println("庄家的得分是:" + dealerScore); System.out.println("你赢了!"); } else if (playerScore == dealerScore) { System.out.println("你的得分是:" + playerScore); System.out.println("庄家的得分是:" + dealerScore); System.out.println("平局!"); } else { System.out.println("你的得分是:" + playerScore); System.out.println("庄家的得分是:" + dealerScore); System.out.println("你输了!"); } } // 抽一张牌,返回牌的点数 public static int drawCard() { int[] cards = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10, 10, 10}; int index = (int) (Math.random() * cards.length); return cards[index]; } } ``` 这个程序主要分为以下几个部分: 1.引入Scanner类,用于接收用户输入。 2.定义玩家得分和庄家得分的变量。 3.循环两次,让玩家和庄家各发两张牌,用drawCard()函数随机生成牌的点数,并将点数加到对应的得分变量中。 4.玩家开始抽牌,使用while循环实现。在循环中,先输出当前得分,然后判断是否爆掉。如果爆掉了,输出游戏结束,并跳出循环;否则提示玩家是否继续抽牌,如果选择抽牌,则继续调用drawCard()函数生成新牌的点数,并加到玩家得分变量中;如果选择不抽牌,则跳出循环。 5.庄家开始抽牌,同样使用while循环实现。在循环中,先输出当前得分,然后判断是否小于17点,如果小于17点,则继续调用drawCard()函数生成新牌的点数,并加到庄家得分变量中。 6.判断输赢。如果庄家的得分大于21点,则玩家赢;如果玩家的得分大于庄家的得分,则玩家赢;如果两者得分相等,则平局;否则玩家输。 7.drawCard()函数,用于随机生成一张牌,返回该牌的点数。 希望这个解答能够帮到您!

相关推荐

编Java程序:2至9牌,按其原点数计算;K、Q、J和10牌都算作10点;A 牌(ace)既可算作1点也可算作11点,由玩家自己决定(当玩家停牌时,点数一律视为最大而尽量不爆,如A+9为20,A+4+8为13,A+3+A视为15)。设计基于指定策略的一个21点游戏的部分功能。 指定策略为:如果手中牌的点数之和小于17点则继续要下一张牌,直到大于等于17点为止。如果手里的牌有A,且A的点数当成11点没有超过21点,则此时A要按11点计算,如果超过21点,则A要按1点计算。 一个参考的设计为:1、设计一个card类,用于保存一张牌;2、设计一个hand类,用于保存一手牌;3、设计一个player类,该类可以基于指定策略完成一次游戏过程。 输入 若干行(至少2行),每行代表一张牌。具体格式见样例。 输出 若干行。 读入前两张牌不输出,从第三张牌开始(如果需要),则每次要牌,要先输出Hit,然后读入下一张牌,并依次输出该牌的花色及点数(A输出1 11,即它有两个点数)。当不再要牌时要先输出Stand,然后在一行内输出这一手牌,牌与牌之间用一个空格分隔。牌输出的顺序为先看牌面,牌面小的在前(牌面由小到大的顺序为A,2,3....J,Q,K),当牌面相同时看花色,输出顺序从前到后为Spade, Heart, Diamond, Club。最后一行输出这一手牌的结果,如果总点数超过21点,则输出Bust,如果是Blackjack(一手牌只有两张牌且点数相加和为21点),则输出Blackjack。其他情况则输出一个整数,代表这手牌的点数(尽量大且不爆)。具体格式见样例。 样例输入 Copy Spade 4 Heart A Heart 3 样例输出 Copy Hit Heart 3 Stand HeartA Heart3 Spade4 18

最新推荐

recommend-type

Java实现简单井字棋小游戏代码实例

主要介绍了Java实现简单井字棋小游戏代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
recommend-type

JAVA实现社会统一信用代码校验的方法

主要介绍了JAVA实现社会统一信用代码校验的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Java实现的打地鼠小游戏完整示例【附源码下载】

主要介绍了Java实现的打地鼠小游戏,结合完整实例形式分析了Java多线程操作及键盘按键响应实现的打地鼠游戏功能相关操作技巧,需要的朋友可以参考下
recommend-type

java通过JFrame做一个登录系统的界面完整代码示例

主要介绍了java通过JFrame做一个登录系统的界面完整代码示例,具有一定借鉴价值,需要的朋友可以参考下。
recommend-type

java实现一个简单的网络爬虫代码示例

主要介绍了java实现一个简单的网络爬虫代码示例,还是挺不错的,这里分享给大家,需要的朋友可以参考下。
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。