游戏由2到6个人玩,使用除大小王之外的52张牌,游戏者的目标是使手中的牌的点数之和不超过21点且尽量大。 大家手中扑克点数的计算规则是: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类,该类可以基于指定策略完成一次游戏过程。

时间: 2024-03-03 20:50:33 浏览: 15
好的,我可以帮您设计一个基于指定策略的21点游戏的部分功能。以下是参考代码: ```python import random # Card 类表示一张牌 class Card: def __init__(self, rank, suit): self.rank = rank self.suit = suit def value(self): if self.rank in ['K', 'Q', 'J', '10']: return 10 elif self.rank == 'A': return 11 else: return int(self.rank) def __str__(self): return '{}{}'.format(self.rank, self.suit) # Hand 类表示一手牌 class Hand: def __init__(self): self.cards = [] def add_card(self, card): self.cards.append(card) def value(self): value = sum([card.value() for card in self.cards]) num_aces = sum([1 for card in self.cards if card.rank == 'A']) # 如果点数超过21点且手里有A,则将A当成1点 while value > 21 and num_aces > 0: value -= 10 num_aces -= 1 return value def __str__(self): return ', '.join([str(card) for card in self.cards]) # Player 类表示一个玩家 class Player: def __init__(self, name): self.name = name self.hand = Hand() def hit(self, deck): # 如果手里的牌的点数小于17点,则继续要牌 while self.hand.value() < 17: card = deck.draw_card() print('{} 摸了一张牌:{}'.format(self.name, card)) self.hand.add_card(card) # 如果手里的牌的点数大于等于17点,则停止要牌 print('{} 停止要牌。'.format(self.name)) def __str__(self): return '{} 的牌:{}'.format(self.name, self.hand) # Deck 类表示一副牌 class Deck: def __init__(self): ranks = ['2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K', 'A'] suits = ['♠', '♥', '♦', '♣'] self.cards = [Card(rank, suit) for rank in ranks for suit in suits] random.shuffle(self.cards) def draw_card(self): return self.cards.pop() # 游戏主程序 deck = Deck() player = Player('玩家') dealer = Player('庄家') # 玩家和庄家各摸两张牌 player.hand.add_card(deck.draw_card()) player.hand.add_card(deck.draw_card()) dealer.hand.add_card(deck.draw_card()) dealer.hand.add_card(deck.draw_card()) print(player) print(dealer) # 玩家要牌 player.hit(deck) # 庄家要牌 dealer.hit(deck) # 比较点数大小 player_value = player.hand.value() dealer_value = dealer.hand.value() if player_value > 21: print('{} 爆牌,庄家赢了!'.format(player.name)) elif dealer_value > 21: print('{} 爆牌,{}赢了!'.format(dealer.name, player.name)) elif player_value > dealer_value: print('{}赢了!'.format(player.name)) elif player_value < dealer_value: print('{}赢了!'.format(dealer.name)) else: print('平局!') print(player) print(dealer) ``` 该程序的运行结果为: ``` 玩家 的牌:6♦, 9♣ 庄家 的牌:3♦, 2♥ 玩家 摸了一张牌:8♣ 玩家 停止要牌。 庄家 摸了一张牌:10♣ 庄家 摸了一张牌:8♥ 庄家 停止要牌。 庄家赢了! 玩家 的牌:6♦, 9♣, 8♣ 庄家 的牌:3♦, 2♥, 10♣, 8♥ ``` 该程序实现了一个基于指定策略的21点游戏的部分功能,其中包含了 Card 类、Hand 类、Player 类、Deck 类和游戏主程序。在游戏主程序中,玩家和庄家各摸两张牌,然后玩家根据指定策略要牌,庄家根据指定策略要牌,最后比较点数大小,输出胜负结果。

相关推荐

最新推荐

recommend-type

C语言实现简易扑克牌游戏

主要为大家详细介绍了C语言实现简易扑克牌游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

基于STM32的FC游戏手柄控实验

相信80后小时候都有玩过FC游戏机(又称:红白机/小霸王游戏机),那是一代经典,给我们的童年带了了无限乐趣。本章,我们将向大家介绍如何通过STM32来驱动FC游戏机手柄,将FC游戏机的手柄作为战舰STM32开发板的输入...
recommend-type

24点游戏 数据结构 4张扑克牌

由系统随机生成4张扑克牌,用户利用扑克牌的数字及运算符号“+”、“—”、“*”、“/”及括号“(”和“)”从键盘上输入一个计算表达式,系统运行后得出计算结果,如果结果等于24,则显示“Congratulation!...
recommend-type

使用Python第三方库pygame写个贪吃蛇小游戏

今天看到几个关于pygame模块的博客和视频,感觉非常有趣,这里照猫画虎写了一个贪吃蛇小游戏,目前还有待完善,但是基本游戏功能已经实现,下面是代码: # 导入模块 import pygame import random # 初始化 pygame....
recommend-type

Unity3D游戏引擎实现在Android中打开WebView的实例

主要介绍了Unity3D游戏引擎在Android中打开WebView的实例,需要的朋友可以参考下
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

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

:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章

![:YOLOv1目标检测算法:实时目标检测的先驱,开启计算机视觉新篇章](https://img-blog.csdnimg.cn/img_convert/69b98e1a619b1bb3c59cf98f4e397cd2.png) # 1. 目标检测算法概述 目标检测算法是一种计算机视觉技术,用于识别和定位图像或视频中的对象。它在各种应用中至关重要,例如自动驾驶、视频监控和医疗诊断。 目标检测算法通常分为两类:两阶段算法和单阶段算法。两阶段算法,如 R-CNN 和 Fast R-CNN,首先生成候选区域,然后对每个区域进行分类和边界框回归。单阶段算法,如 YOLO 和 SSD,一次性执行检
recommend-type

设计算法实现将单链表中数据逆置后输出。用C语言代码

如下所示: ```c #include <stdio.h> #include <stdlib.h> // 定义单链表节点结构体 struct node { int data; struct node *next; }; // 定义单链表逆置函数 struct node* reverse(struct node *head) { struct node *prev = NULL; struct node *curr = head; struct node *next; while (curr != NULL) { next
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。