本课程为吉林大学软件学院卓班开设的设计模式系列练习之一,旨在通过实践巩固学生对各种设计模式的理解与应用能力。
作业04 行为型+其它
1. 将游戏中的玩家分为两个类:HumanPlayer 和 AutoPlayer。初始状态下,每个玩家都位于地图的第一个Block上,并且初始移动方向任意。每一轮次中,HumanPlayer前进3格,AutoPlayer前进2格。前进的方向可以是四个可能的选项(前、左、右),但不能往回走。如果前方有可选路径,则必须选择一个可行的方向进行前进。
- HumanPlayer所在的Block用[X]表示。
- AutoPlayer所在的Block用(X)表示。
请根据上述要求编写代码实现功能。
2. 在Players类中,通过getFirst和getLast函数获取两个玩家对象,但这两个成员函数与使用deque存储玩家紧密相关,并且只能取得前后两位的玩家。考虑到游戏中可能有多个玩家并且数据结构可以多样化,请采用迭代器模式重新设计遍历所有Player的功能。
- 实现C++风格的外部迭代器类 CppIterator 和 Java风格的外部迭代器类JavaIterator。
3. 玩家在前进时,不同的策略会导致不同的移动方式。如等概率随机选择方向和根据给定的概率分布表进行决策(具体见下)。而且未来可能会添加新的行进策略或让玩家动态改变策略。
- 使用策略模式实现这一功能,并提供相应的接口以支持多种可能的行进策略。
4. 为了增加游戏趣味性,引入了卡片子系统与魔法子系统。Player能够使用这些卡牌和法术来影响其它对象或自身状态:
- 修改PlayMenu为: PlayMenu1. Go...2. ApplyRobCard3. ApplyMeanCard4. ApplyReturnSpell5. Load6. Save7. Back To MainMenuYour selected: 并给Player类添加ApplyRobCard(Player * target)、ApplyMeanCard();和ApplyReturnSpell(Player * target),实现上述功能。
- 未来可能加入更多卡牌与法术,且这些新的元素作用的目标可能是Player、Block等。为了便于扩展而不需直接从Player或其子类派生新类型,请使用命令模式。
5. 增加FlyCard和FreezeSpell以影响玩家的移动速度:
- 使用状态模式实现上述功能。
6. 若还需要增加HurtSpell,该法术会导致被作用的Player每轮次减少Money的数量为5,并持续2个轮次;增加LuckCard,使持有者在保持幸运状态下额外获得金钱。同时,引入ExFlyCard和SuperCard以增强玩家的能力或改变游戏规则。
- 实现上述功能时,请确保多个卡牌/法术效果可以共存。
7. 若某个Player的money小于等于0,则表示该player破产了,并退出当前的游戏过程;所有继续进行中的玩家需要减半他们的Money,同时将TripBlock的惩罚调整为200。如果所有的HumanPlayers都已破产,游戏返回到主菜单;若只剩一个HumanPlayer而其它AutoPlayers均已破产的话则显示胜利信息并回到主菜单。
8. 若各Player又分两种高富帅和白富美等有限几种类型。应用不同的Card、Spell等到不同类型玩家时可能产生不同效果。
- 请以访问者模式设计实现上述需求,以便于未来可以扩展更多类型的卡牌与法术,并且能够灵活地为每种类型定义特定的效果。