我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python+Pygame怎么实现24点游戏

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python+Pygame怎么实现24点游戏

这篇文章主要介绍了Python+Pygame怎么实现24点游戏的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python+Pygame怎么实现24点游戏文章都会有所收获,下面我们一起来看看吧。

游戏介绍

(1)什么是24点游戏

棋牌类益智游戏,要求结果等于二十四

(2)游戏规则

任意抽取4个数字(1——10),用加、减、乘、除(可加括号)把出现的数算成24。每个数字必须用一次且只能用一次。“算24点”作为一种锻炼思维的智力游戏,还应注意计算中的技巧问题。计算时,我们不可能把牌面上的4个数的不同组合形式——去试,更不能瞎碰乱凑。

例:3、8、8、9

答案:3×8÷(9-8)=24

实现代码

1.定义游戏这部分代码小写game.py文件

'''    定义游戏'''import copyimport randomimport pygame'''Function:    卡片类Initial Args:    --x,y: 左上角坐标    --width: 宽    --height: 高    --text: 文本    --font: [字体路径, 字体大小]    --font_colors(list): 字体颜色    --bg_colors(list): 背景色'''class Card(pygame.sprite.Sprite):    def __init__(self, x, y, width, height, text, font, font_colors, bg_colors, attribute, **kwargs):        pygame.sprite.Sprite.__init__(self)        self.rect = pygame.Rect(x, y, width, height)        self.text = text        self.attribute = attribute        self.font_info = font        self.font = pygame.font.Font(font[0], font[1])        self.font_colors = font_colors        self.is_selected = False        self.select_order = None        self.bg_colors = bg_colors    '''画到屏幕上'''    def draw(self, screen, mouse_pos):        pygame.draw.rect(screen, self.bg_colors[1], self.rect, 0)        if self.rect.collidepoint(mouse_pos):            pygame.draw.rect(screen, self.bg_colors[0], self.rect, 0)        font_color = self.font_colors[self.is_selected]        text_render = self.font.render(self.text, True, font_color)        font_size = self.font.size(self.text)        screen.blit(text_render, (self.rect.x+(self.rect.width-font_size[0])/2, self.rect.y+(self.rect.height-font_size[1])/2))'''按钮类'''class Button(Card):    def __init__(self, x, y, width, height, text, font, font_colors, bg_colors, attribute, **kwargs):        Card.__init__(self, x, y, width, height, text, font, font_colors, bg_colors, attribute)    '''根据button function执行响应操作'''    def do(self, game24_gen, func, sprites_group, objs):        if self.attribute == 'NEXT':            for obj in objs:                obj.font = pygame.font.Font(obj.font_info[0], obj.font_info[1])                obj.text = obj.attribute            self.font = pygame.font.Font(self.font_info[0], self.font_info[1])            self.text = self.attribute            game24_gen.generate()            sprites_group = func(game24_gen.numbers_now)        elif self.attribute == 'RESET':            for obj in objs:                obj.font = pygame.font.Font(obj.font_info[0], obj.font_info[1])                obj.text = obj.attribute            game24_gen.numbers_now = game24_gen.numbers_ori            game24_gen.answers_idx = 0            sprites_group = func(game24_gen.numbers_now)        elif self.attribute == 'ANSWERS':            self.font = pygame.font.Font(self.font_info[0], 20)            self.text = '[%d/%d]: ' % (game24_gen.answers_idx+1, len(game24_gen.answers)) + game24_gen.answers[game24_gen.answers_idx]            game24_gen.answers_idx = (game24_gen.answers_idx+1) % len(game24_gen.answers)        else:            raise ValueError('Button.attribute unsupport %s, expect %s, %s or %s...' % (self.attribute, 'NEXT', 'RESET', 'ANSWERS'))        return sprites_group'''24点游戏生成器'''class game24Generator():    def __init__(self):        self.info = 'game24Generator'    '''生成器'''    def generate(self):        self.__reset()        while True:            self.numbers_ori = [random.randint(1, 10) for i in range(4)]            self.numbers_now = copy.deepcopy(self.numbers_ori)            self.answers = self.__verify()            if self.answers:                break    '''只剩下一个数字时检查是否为24'''    def check(self):        if len(self.numbers_now) == 1 and float(self.numbers_now[0]) == self.target:            return True        return False    '''重置'''    def __reset(self):        self.answers = []        self.numbers_ori = []        self.numbers_now = []        self.target = 24.        self.answers_idx = 0    '''验证生成的数字是否有答案'''    def __verify(self):        answers = []        for item in self.__iter(self.numbers_ori, len(self.numbers_ori)):            item_dict = []            list(map(lambda i: item_dict.append({str(i): i}), item))            solution1 = self.__func(self.__func(self.__func(item_dict[0], item_dict[1]), item_dict[2]), item_dict[3])            solution2 = self.__func(self.__func(item_dict[0], item_dict[1]), self.__func(item_dict[2], item_dict[3]))            solution = dict()            solution.update(solution1)            solution.update(solution2)            for key, value in solution.items():                if float(value) == self.target:                    answers.append(key)        # 避免有数字重复时表达式重复(T_T懒得优化了)        answers = list(set(answers))        return answers    '''递归枚举'''    def __iter(self, items, n):        for idx, item in enumerate(items):            if n == 1:                yield [item]            else:                for each in self.__iter(items[:idx]+items[idx+1:], n-1):                    yield [item] + each    '''计算函数'''    def __func(self, a, b):        res = dict()        for key1, value1 in a.items():            for key2, value2 in b.items():                res.update({'('+key1+'+'+key2+')': value1+value2})                res.update({'('+key1+'-'+key2+')': value1-value2})                res.update({'('+key2+'-'+key1+')': value2-value1})                res.update({'('+key1+'×'+key2+')': value1*value2})                value2 > 0 and res.update({'('+key1+'÷'+key2+')': value1/value2})                value1 > 0 and res.update({'('+key2+'÷'+key1+')': value2/value1})        return res

2.游戏主函数

def main():    # 初始化, 导入必要的游戏素材    pygame.init()    pygame.mixer.init()    screen = pygame.display.set_mode(SCREENSIZE)    pygame.display.set_caption('24点小游戏')    win_sound = pygame.mixer.Sound(AUDIOWINPATH)    lose_sound = pygame.mixer.Sound(AUDIOLOSEPATH)    warn_sound = pygame.mixer.Sound(AUDIOWARNPATH)    pygame.mixer.music.load(BGMPATH)    pygame.mixer.music.play(-1, 0.0)    # 24点游戏生成器    game24_gen = game24Generator()    game24_gen.generate()    # 精灵组    # --数字    number_sprites_group = getNumberSpritesGroup(game24_gen.numbers_now)    # --运算符    operator_sprites_group = getOperatorSpritesGroup(OPREATORS)    # --按钮    button_sprites_group = getButtonSpritesGroup(BUTTONS)    # 游戏主循环    clock = pygame.time.Clock()    selected_numbers = []    selected_operators = []    selected_buttons = []    is_win = False    while True:        for event in pygame.event.get():            if event.type == pygame.QUIT:                pygame.quit()                sys.exit(-1)            elif event.type == pygame.MOUSEBUTTONUP:                mouse_pos = pygame.mouse.get_pos()                selected_numbers = checkClicked(number_sprites_group, mouse_pos, 'NUMBER')                selected_operators = checkClicked(operator_sprites_group, mouse_pos, 'OPREATOR')                selected_buttons = checkClicked(button_sprites_group, mouse_pos, 'BUTTON')        screen.fill(AZURE)        # 更新数字        if len(selected_numbers) == 2 and len(selected_operators) == 1:            noselected_numbers = []            for each in number_sprites_group:                if each.is_selected:                    if each.select_order == '1':                        selected_number1 = each.attribute                    elif each.select_order == '2':                        selected_number2 = each.attribute                    else:                        raise ValueError('Unknow select_order %s, expect 1 or 2...' % each.select_order)                else:                    noselected_numbers.append(each.attribute)                each.is_selected = False            for each in operator_sprites_group:                each.is_selected = False            result = calculate(selected_number1, selected_number2, *selected_operators)            if result is not None:                game24_gen.numbers_now = noselected_numbers + [result]                is_win = game24_gen.check()                if is_win:                    win_sound.play()                if not is_win and len(game24_gen.numbers_now) == 1:                    lose_sound.play()            else:                warn_sound.play()            selected_numbers = []            selected_operators = []            number_sprites_group = getNumberSpritesGroup(game24_gen.numbers_now)        # 精灵都画到screen上        for each in number_sprites_group:            each.draw(screen, pygame.mouse.get_pos())        for each in operator_sprites_group:            each.draw(screen, pygame.mouse.get_pos())        for each in button_sprites_group:            if selected_buttons and selected_buttons[0] in ['RESET', 'NEXT']:                is_win = False            if selected_buttons and each.attribute == selected_buttons[0]:                each.is_selected = False                number_sprites_group = each.do(game24_gen, getNumberSpritesGroup, number_sprites_group, button_sprites_group)                selected_buttons = []            each.draw(screen, pygame.mouse.get_pos())        # 游戏胜利        if is_win:            showInfo('Congratulations', screen)        # 游戏失败        if not is_win and len(game24_gen.numbers_now) == 1:            showInfo('Game Over', screen)        pygame.display.flip()        clock.tick(30)

游戏效果展示

Python+Pygame怎么实现24点游戏

Python+Pygame怎么实现24点游戏

关于“Python+Pygame怎么实现24点游戏”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Python+Pygame怎么实现24点游戏”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python+Pygame怎么实现24点游戏

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python+Pygame怎么实现24点游戏

这篇文章主要介绍了Python+Pygame怎么实现24点游戏的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python+Pygame怎么实现24点游戏文章都会有所收获,下面我们一起来看看吧。游戏介绍(1)什么
2023-06-30

如何使用Python Pygame实现24点游戏

这篇文章主要讲解了“如何使用Python Pygame实现24点游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Python Pygame实现24点游戏”吧!游戏介绍(1)什么是2
2023-07-06

Python Pygame怎么实现塔防游戏

这篇文章主要讲解了“Python Pygame怎么实现塔防游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python Pygame怎么实现塔防游戏”吧!一、环境要求windows系统,p
2023-06-29

怎么用Python Pygame实现赛车游戏

今天小编给大家分享一下怎么用Python Pygame实现赛车游戏的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、环境安装
2023-06-29

Python+Pygame怎么实现吃豆豆游戏

这篇文章主要介绍了Python+Pygame怎么实现吃豆豆游戏的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python+Pygame怎么实现吃豆豆游戏文章都会有所收获,下面我们一起来看看吧。一、首先1)素材首
2023-07-02

怎么用Python制作24点小游戏

这篇文章主要介绍“怎么用Python制作24点小游戏”,在日常操作中,相信很多人在怎么用Python制作24点小游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python制作24点小游戏”的疑惑有所
2023-06-29

C语言怎么实现24点游戏计算器

要实现24点游戏计算器,可以使用递归的方法来进行计算。以下是一个简单的C语言实现:```c#include #include #define TARGET 24#define EPSILON 1e-6bool solve24(double
2023-08-18

怎么使用Python+Pygame实现泡泡游戏

这篇文章主要讲解了“怎么使用Python+Pygame实现泡泡游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Python+Pygame实现泡泡游戏”吧!一、环境安装1)素材(图片
2023-07-02

基于Python实现24点游戏的示例代码

这篇文章主要为大家详细介绍了如何利用Python实现24点游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
2022-12-08

怎么用Python Pygame实现的画饼图游戏

这篇文章主要介绍“怎么用Python Pygame实现的画饼图游戏”,在日常操作中,相信很多人在怎么用Python Pygame实现的画饼图游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python
2023-06-22

Python+Pygame怎么实现疯狂吃水果游戏

这篇文章主要介绍“Python+Pygame怎么实现疯狂吃水果游戏”,在日常操作中,相信很多人在Python+Pygame怎么实现疯狂吃水果游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python+Py
2023-07-02

Python+Pygame实现接小弹珠游戏

这篇文章主要为大家详细介绍了Python如何利用Pygame实现接小弹珠游戏,即用挡板接住会反弹的小球,随着次数的增多,速度变快,分数增多,感兴趣的可以了解一下
2022-12-27

基于Python+Pygame怎么实现经典赛车游戏

这篇文章主要介绍“基于Python+Pygame怎么实现经典赛车游戏”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于Python+Pygame怎么实现经典赛车游戏”文章能帮助大家解决问题。一、环境
2023-06-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录