用python写一个大于100行代码的小游戏多注释

时间: 2024-01-26 10:02:58 浏览: 21
好的,我给您提供一个比较复杂的小游戏,带有注释,总共超过100行代码。这个游戏是一个简化版的石头剪刀布游戏,玩家和电脑对战,可以选择不同的角色和游戏模式。 ```python import random # 导入随机数模块 # 游戏角色类,包括角色名、角色属性和角色技能 class Character: def __init__(self, name, hp, atk, skill): self.name = name self.hp = hp self.atk = atk self.skill = skill # 游戏技能类,包括技能名、技能属性和技能效果 class Skill: def __init__(self, name, attribute, effect): self.name = name self.attribute = attribute self.effect = effect # 游戏属性类,包括属性名、属性优劣和属性克制关系 class Attribute: def __init__(self, name, advantage, disadvantage, counter): self.name = name self.advantage = advantage self.disadvantage = disadvantage self.counter = counter # 定义游戏角色、技能和属性 rockman = Character("洛克人", 100, 20, Skill("洛克炮", "炮击", 30)) cutman = Character("卡特人", 80, 30, Skill("切割器", "斩击", 25)) bombman = Character("爆弹人", 120, 15, Skill("爆弹", "爆炸", 35)) fireman = Character("火焰人", 90, 25, Skill("火焰", "火焰", 20)) piercing = Attribute("炮击", "斩击", "火焰", "爆炸") slashing = Attribute("斩击", "火焰", "炮击", "爆炸") explosion = Attribute("爆炸", "炮击", "斩击", "火焰") fire = Attribute("火焰", "斩击", "炮击", "爆炸") # 定义游戏模式 modes = { "1": ("剪刀", "石头", "布"), "2": ("炮击", "斩击", "爆炸", "火焰") } # 游戏开始 print("欢迎来到石头剪刀布游戏!") print("请选择角色:") print(f"1. {rockman.name}") print(f"2. {cutman.name}") print(f"3. {bombman.name}") print(f"4. {fireman.name}") while True: player_choice = input("输入数字选择角色:") # 玩家选择角色 if player_choice in ("1", "2", "3", "4"): break else: print("输入有误,请重新选择!") # 根据玩家选择的角色,设置电脑角色 if player_choice == "1": computer = random.choice((cutman, bombman, fireman)) elif player_choice == "2": computer = random.choice((rockman, bombman, fireman)) elif player_choice == "3": computer = random.choice((rockman, cutman, fireman)) else: computer = random.choice((rockman, cutman, bombman)) print(f"你选择了{eval(f'rockman.name if player_choice == "1" else cutman.name if player_choice == "2" else bombman.name if player_choice == "3" else fireman.name')},电脑选择了{computer.name}。") # 等待玩家选择游戏模式 while True: print("请选择游戏模式:") print("1. 简单模式(剪刀石头布)") print("2. 困难模式(炮击斩击爆炸火焰)") mode_choice = input("输入数字选择模式:") if mode_choice in ("1", "2"): break else: print("输入有误,请重新选择!") mode = modes[mode_choice] player_score = 0 # 玩家得分 computer_score = 0 # 电脑得分 round_count = 1 # 当前回合数 while True: print(f"第{round_count}回合:") print(f"{rockman.name}的生命值:{rockman.hp},{cutman.name}的生命值:{cutman.hp},{bombman.name}的生命值:{bombman.hp},{fireman.name}的生命值:{fireman.hp}。") print(f"你的得分:{player_score},电脑的得分:{computer_score}。") print(f"请选择你的出招(1-{len(mode)}):") for i in range(len(mode)): print(f"{i+1}. {mode[i]}") player_choice = input("输入数字选择出招:") # 等待玩家出招 if player_choice not in tuple(map(str, range(1, len(mode)+1))): print("输入有误,请重新出招!") continue player_choice = mode[int(player_choice)-1] computer_choice = random.choice(mode) # 随机选择电脑出招 # 根据出招属性和技能,计算出招伤害 if getattr(player_choice, "attribute") == getattr(computer_choice, "advantage"): damage = getattr(player_choice, "skill").effect print(f"你使用了{player_choice.name},电脑使用了{computer_choice.name},造成了{damage}点伤害!") setattr(computer, "hp", getattr(computer, "hp") - damage) elif getattr(player_choice, "attribute") == getattr(computer_choice, "disadvantage"): damage = getattr(computer_choice, "skill").effect print(f"你使用了{player_choice.name},电脑使用了{computer_choice.name},但是被电脑{getattr(computer_choice, 'attribute')}属性克制,你受到了{damage}点伤害!") setattr(rockman if player_choice == rockman.skill.attribute else cutman if player_choice == cutman.skill.attribute else bombman if player_choice == bombman.skill.attribute else fireman, "hp", getattr(rockman if player_choice == rockman.skill.attribute else cutman if player_choice == cutman.skill.attribute else bombman if player_choice == bombman.skill.attribute else fireman, "hp") - damage) else: print(f"你使用了{player_choice.name},电脑使用了{computer_choice.name},但是没有造成伤害。") # 根据角色的生命值判断胜负 if getattr(computer, "hp") <= 0: print(f"恭喜你,你赢了!") player_score += 1 break elif getattr(rockman if player_choice == rockman.skill.attribute else cutman if player_choice == cutman.skill.attribute else bombman if player_choice == bombman.skill.attribute else fireman, "hp") <= 0: print(f"很遗憾,你输了!") computer_score += 1 break else: round_count += 1 # 如果回合数超过10,强制结束游戏 if round_count > 10: print("回合数超过10,游戏强制结束!") break # 如果当前得分差距大于等于3,强制结束游戏 if abs(player_score - computer_score) >= 3: print("当前得分差距大于等于3,游戏强制结束!") break # 打印最终结果 if player_score > computer_score: print("你赢了!") elif player_score < computer_score: print("你输了!") else: print("平局!") print("谢谢游玩,再见!") ``` 这个游戏比较复杂,包含了角色、技能和属性等多个类别,还有不同的游戏模式和回合制的对战机制。希望这个游戏能够为您提供参考。

相关推荐

最新推荐

recommend-type

20行python代码的入门级小游戏的详解

主要介绍了python入门级小游戏,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Python小游戏之300行代码实现俄罗斯方块

主要给大家介绍了关于Python小游戏之300行代码实现俄罗斯方块的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧
recommend-type

不到40行代码用Python实现一个简单的推荐系统

主要给大家介绍了如何利用不到40行python代码实现一个简单的推荐系统,文中通过示例代码介绍的非常详细,对大家学习或者使用Python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
recommend-type

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

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

Python实现打砖块小游戏代码实例

主要介绍了Python打砖块小游戏,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
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的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。