C/C++语言文字小游戏(荒岛求生)

游戏背景

玩家在荒岛上,需要寻找食物、水源、避难所等资源来生存。
玩家需要避免危险,如野兽、植物、天气等,否则会失去血量或生命。
玩家可以在荒岛上遇到其他生存者,可以选择合作或对抗。
游戏目标是生存一定时间或找到生存的出路。

游戏玩法思路

这个荒岛求生游戏的代码实现了一个简单的文本控制台游戏,玩家需要在荒岛上生存并尽力寻找资源以保持生机。以下是游戏的基本思路:

  1. 游戏开始时,玩家会被提示输入命令,可以输入’h’查看帮助信息。

  2. 玩家通过输入不同的命令来执行相应的操作:

    • ‘s’:显示幸存者当前状态,包括名字、健康值、饥饿度和口渴度。
    • ‘m’:搜索周围的地图资源,可能会发现食物、水源或者避难所,并有可能遇到危险。
    • ‘r’:休息一下,健康值会回复一定数值。
    • ‘f’:查找食物,如果周围有食物则可以减少饥饿度。
    • ‘w’:查找水源,如果周围有水源则可以减少口渴度。
    • ‘e’:进入避难所,可以提高健康值。
    • ‘c’:与其他幸存者合作,可能会共同搜索资源或者对抗。
    • ‘a’:与其他幸存者对抗,可能会获胜也可能会受伤。
    • ‘q’:退出游戏。
  3. 游戏会根据玩家的选择和随机事件更新幸存者的状态,包括健康值、饥饿度和口渴度。

  4. 如果幸存者的饥饿度、口渴度或健康值降至零或以下,游戏结束,玩家死亡。

  5. 游戏循环执行,玩家可以根据当前状态和情况灵活选择不同的操作,尽力延长生存时间并最终生还。

这个游戏的核心玩法在于根据当前状态和资源情况进行合理的选择,同时还需要考虑随机事件的影响。玩家需要平衡健康、饥饿和口渴的关系,尽量延长生存时间。

运行示例
在这里插入图片描述

结构体和全局变量定义

#define MAX_NAME_LEN 20    // 最大名字长度
#define INITIAL_HEALTH 100 // 初始健康值
#define INITIAL_HUNGER 50  // 初始饥饿度
#define INITIAL_THIRST 50  // 初始口渴度// 荒岛地图结构体
typedef struct {int hasShelter; // 是否有避难所int hasFood;    // 是否有食物int hasWater;   // 是否有水源int hasDanger;  // 是否存在危险
} Map;// 幸存者状态结构体
typedef struct {char name[MAX_NAME_LEN]; // 名字int health;              // 健康值int hunger;              // 饥饿度int thirst;              // 口渴度
} Survivor;

主函数

int main() {srand(time(NULL));  // 用当前时间初始化随机数种子Survivor player = {"玩家", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};Map map = {0, 0, 0, 0};  // 初始化荒岛地图printf("欢迎来到荒岛求生游戏!输入'h'查看帮助信息。\n");while (1) {char choice;std::cin>>choice;switch (choice) {case 'h':displayHelp();break;case 's':printSurvivorStatus(&player);break;case 'm':searchResources(&map, &player);break;case 'r':printf("你摆开行囊好好休息了一下,健康值回复了20点。\n");player.health += 20;break;case 'f':findFood(&map, &player);break;case 'w':findWater(&map, &player);break;case 'e':enterShelter(&map, &player);break;case 'c': {Survivor stranger = {"陌生人", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};showSurvivorsEncountered(&player, &stranger);break;}case 'a': {Survivor enemy = {"敌人", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};showSurvivorsEncountered(&player, &enemy);break;}case 'q':printf("游戏结束,再见!\n");return 0;default:printf("无效的命令,请查看帮助信息。\n");break;}// 幸存者状态检查if (player.hunger <= 0 || player.thirst <= 0 || player.health <= 0) {printf("很遗憾,你已经死亡了。\n");return 0;}}return 0;
}

源代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <iostream>#define MAX_NAME_LEN 20    // 最大名字长度
#define INITIAL_HEALTH 100 // 初始健康值
#define INITIAL_HUNGER 50  // 初始饥饿度
#define INITIAL_THIRST 50  // 初始口渴度// 荒岛地图结构体
typedef struct {int hasShelter; // 是否有避难所int hasFood;    // 是否有食物int hasWater;   // 是否有水源int hasDanger;  // 是否存在危险
} Map;// 幸存者状态结构体
typedef struct {char name[MAX_NAME_LEN]; // 名字int health;              // 健康值int hunger;              // 饥饿度int thirst;              // 口渴度
} Survivor;// 显示帮助信息
void displayHelp() {printf("你被困在了荒岛上,请尽力寻找资源保持生机并最终生还。\n");printf("以下是每个命令的含义:\n");printf("h - 帮助\n");printf("s - 显示幸存者当前状态\n");printf("m - 搜索周围的地图资源\n");printf("r - 休息\n");printf("f - 查找食物\n");printf("w - 查找水源\n");printf("e - 进入避难所\n");printf("c - 与其他幸存者合作\n");printf("a - 与其他幸存者对抗\n");printf("q - 退出游戏\n");
}// 显示幸存者状态
void printSurvivorStatus(Survivor* survivor) {printf("名字:%s\n", survivor->name);printf("健康值:%d\n", survivor->health);printf("饥饿度:%d\n", survivor->hunger);printf("口渴度:%d\n", survivor->thirst);
}// 搜索资源
void searchResources(Map* map, Survivor* survivor) {int randFind = rand() % 2;   // 模拟搜索结果if (randFind == 0) {printf("很遗憾,你没有发现任何资源。\n");} else {printf("恭喜你,你发现了一些资源!\n");int randResource = rand() % 3;  // 模拟资源类型switch (randResource) {case 0:printf("你发现了一些果子,你的饥饿度下降了10!\n");survivor->hunger -= 10;map->hasFood = 1;break;case 1:printf("你找到了一处小溪流,你的口渴度下降了10!\n");survivor->thirst -= 10;map->hasWater = 1;break;case 2:printf("你发现了一个避难所,可能是躲避危险的好地方!\n");map->hasShelter = 1;break;}}int randDanger = rand() % 2;   // 模拟危险出现概率if (randDanger == 0) {printf("很不幸,你碰到了危险!\n");map->hasDanger = 1;}
}// 查找食物
void findFood(Map* map, Survivor* survivor) {if (!map->hasFood) {printf("很遗憾,你没有找到任何食物。\n");return;}printf("你找到了一些水果,你的饥饿度下降了20。\n");survivor->hunger -= 20;map->hasFood = 0;
}// 查找水源
void findWater(Map* map, Survivor* survivor) {if (!map->hasWater) {printf("很遗憾,你没有找到任何水源。\n");return;}printf("你找到了一些清水,你的口渴度下降了20。\n");survivor->thirst -= 20;map->hasWater = 0;
}// 进入避难所
void enterShelter(Map* map, Survivor* survivor) {if (!map->hasShelter) {printf("很遗憾,你还没有找到避难所。\n");return;}printf("你找到了避难所,可以好好休息一下!\n");survivor->health = 100;
}// 回避危险
void avoidDanger(Map* map, Survivor* survivor) {if (!map->hasDanger) {printf("现在岛上很平静,没有什么可担心的。\n");return;}int randEscape = rand() % 2;  // 模拟逃脱概率if (randEscape == 0) {printf("很遗憾,你被困住了,受到了伤害!\n");survivor->health -= 20;} else {printf("你成功逃脱了危险!\n");}
}// 显示遇到的其他幸存者
void showSurvivorsEncountered(Survivor* player, Survivor* stranger) {printf("你遇到了一个幸存者:%s\n", stranger->name);printf("他的状态是:\n");printSurvivorStatus(stranger);printf("是否与他合作?(y/n)");char choice;getchar();scanf("%c", &choice);if (choice == 'y') {// 计算合作效果int randCoop = rand() % 2;if (randCoop == 0) {printf("很遗憾,你们一起搜索时没有找到任何资源。\n");} else {printf("你们成功找到了一些资源!\n");int randResource = rand() % 3;switch (randResource) {case 0:printf("你们找到了一些香蕉,你的饥饿度下降了10!\n");player->hunger -= 10;stranger->hunger -= 10;break;case 1:printf("你们找到了一口井,你的口渴度下降了10!\n");player->thirst -= 10;stranger->thirst -= 10;break;case 2:printf("你们发现了一处废弃宿舍,可以休息片刻!\n");player->health += 20;stranger->health += 20;break;}}} else {// 计算对抗结果int randVs = rand() % 2;if (randVs == 0) {printf("很遗憾,你被幸存者%s打败了!\n", stranger->name);player->health -= 30;} else {printf("你成功击败了幸存者%s,但也受到了一些伤害。\n", stranger->name);player->health -= 20;}}
}int main() {srand(time(NULL));  // 用当前时间初始化随机数种子Survivor player = {"玩家", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};Map map = {0, 0, 0, 0};  // 初始化荒岛地图printf("欢迎来到荒岛求生游戏!输入'h'查看帮助信息。\n");while (1) {char choice;std::cin>>choice;switch (choice) {case 'h':displayHelp();break;case 's':printSurvivorStatus(&player);break;case 'm':searchResources(&map, &player);break;case 'r':printf("你摆开行囊好好休息了一下,健康值回复了20点。\n");player.health += 20;break;case 'f':findFood(&map, &player);break;case 'w':findWater(&map, &player);break;case 'e':enterShelter(&map, &player);break;case 'c': {Survivor stranger = {"陌生人", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};showSurvivorsEncountered(&player, &stranger);break;}case 'a': {Survivor enemy = {"敌人", INITIAL_HEALTH, INITIAL_HUNGER, INITIAL_THIRST};showSurvivorsEncountered(&player, &enemy);break;}case 'q':printf("游戏结束,再见!\n");return 0;default:printf("无效的命令,请查看帮助信息。\n");break;}// 幸存者状态检查if (player.hunger <= 0 || player.thirst <= 0 || player.health <= 0) {printf("很遗憾,你已经死亡了。\n");return 0;}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/708006.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Javaweb之SpringBootWeb案例之 Bean管理的第三方Bean的详细解析

2.3 第三方Bean 学习完bean的获取、bean的作用域之后&#xff0c;接下来我们再来学习第三方bean的配置。 之前我们所配置的bean&#xff0c;像controller、service&#xff0c;dao三层体系下编写的类&#xff0c;这些类都是我们在项目当中自己定义的类(自定义类)。当我们要声…

将任何网页变成桌面应用,全平台支持 | 开源日报 No.184

tw93/Pake Stars: 20.9k License: MIT Pake 是利用 Rust 轻松构建轻量级多端桌面应用的工具。 与 Electron 包大小相比几乎小了 20 倍&#xff08;约 5M&#xff01;&#xff09;使用 Rust Tauri&#xff0c;Pake 比基于 JS 的框架更轻量和更快内置功能包括快捷方式传递、沉浸…

常见设计模式之单例模式

单例模式 单例模式是一种常用的软件设计模式&#xff0c;主要目的是确保一个类在整个应用程序生命周期中只有一个实例&#xff0c;并提供一个全局访问点以获取该实例。 单例模式分为几种不同的实现方式&#xff0c;包括懒汉模式和饿汉模式。每种方式都有其特点和适用场景。例如…

vue或者uniapp修改数据后页面不重新渲染

1.数据是对象 通常是某个渲染的数组改变了层级较深的数据导致页面没有实时渲染 this.itemsJSON.parse(JSON.stringify(this.items)); 2.数据是数组 this.$set 方法&#xff0c;可以显式地告诉Vue&#xff0c;某个属性的值已经发生了变化&#xff0c;从而触发视图的更新 le…

小程序中使用echarts地图

一、下载并安装echarts 1、下载echarts-for-weixin组件 echarts-for-weixin项目提供了一个小程序组件&#xff0c;用这种方式可以在小程序中方便地使用 ECharts。 下载ec-canvas项目&#xff08;下载地址&#xff09; ​​ 注意&#xff1a;下载的 ec-canvas 中的echarts的版本…

sql中COALESCE函数详解

在SQL中&#xff0c;COALESCE函数是一个非常有用的函数&#xff0c;用于从其参数列表中返回第一个非NULL值。如果所有给定的参数都是NULL&#xff0c;那么COALESCE函数将返回NULL。这个函数可以接受多个参数&#xff0c;使其在处理可能出现的NULL值时非常灵活和强大。 语法 C…

【Linux】协程简介

【Linux】协程简介 一、什么是协程&#xff1f;简介优点 二、为什么使用协程&#xff1f;三、协程的种类1、对称协程2、非对称协程 四、协程栈1、静态栈2、分段栈3、共享栈4、虚拟内存栈 五、协程调度1、栈式调度2、星切调度3、环切调度 六、常见协程库参考文献 一、什么是协程…

word embedding

介绍&#xff1a; ASCII可以编码为计算机可以识别的数据&#xff0c;为什么还需要embedding? 计算机只是对“字母”进行ASCII编码&#xff0c;并没有对词汇的“Word”编码。词汇应该是咱们处理自然语言的最基本的元素&#xff0c;而不是字母。那么世界上有千千万万的Word&am…

力扣381. O(1) 时间插入、删除和获取随机元素 - 允许重复

RandomizedCollection 是一种包含数字集合(可能是重复的)的数据结构。它应该支持插入和删除特定元素&#xff0c;以及删除随机元素。 实现 RandomizedCollection 类: RandomizedCollection()初始化空的 RandomizedCollection 对象。 bool insert(int val) 将一个 val 项插入到…

机器学习 | 模型评估和选择 各种评估指标总结——错误率精度-查准率查全率-真正例率假正例率 PR曲线ROC曲线

文章目录 1. 如何产生训练集和测试集呢&#xff1f;1.1 留出法1.2 K折交叉验证法1.3 自助法 2. 模型评估指标2.1 错误率和精度2.2 查准率和查全率与F12.2.1 PR曲线及其绘制 2.3 正例率和假例率2.3.1 ROC曲线图绘制及AUC 3 假设检验 1. 如何产生训练集和测试集呢&#xff1f; 1…

mac配置环境变量总结

1、启动终端Terminal 2、进入当前用户的home目录 输入 cd &#xff5e; (注意中间的空格) 3、创建 .bash_profile 文件 输入 touch .bash_profile 4、编辑 .bash_profile文件 输入 open -e .bash_profile .bash_profile文件内容 5、更新配置 source ~/.bash_profile…

Java的泛型特性和PECS特性

Java的泛型特性是Java SE 5引入的&#xff0c;它提供了编译时类型安全检测机制&#xff0c;这意味着程序可以在编译期间检测到类型错误&#xff0c;而不是在运行时。泛型的引入极大地增强了程序的类型安全性&#xff0c;减少了强制类型转换的需要。以下是Java泛型特性的详细解释…

【ACW 服务端】k8s部署

k8s部署 --- apiVersion: apps/v1 kind: Deployment metadata:annotations:k8s.kuboard.cn/displayName: 【wu-smart-acw-server】后台服务端labels:k8s.kuboard.cn/layer: svck8s.kuboard.cn/name: wu-smart-acw-servername: wu-smart-acw-servernamespace: defaultresourceV…

python 处理B站视频数据,数据存本地

python 处理B站视频数据&#xff0c;数据存本地 绪论实现1 导入头文件2. 获得数据的函数3 获取dvid4 获取数据&#xff0c;保存 后续 绪论 上一个已经通过B站的API&#xff0c;来实现了对数据的读取&#xff0c;这篇文章就是&#xff0c;将数据存储在本地的TXT文件中 上一篇文…

记autodl跑模型GPU CPU利用率骤变为0问题

目录 问题 解决 问题 实验室服务器资源紧张&#xff0c;博主就自己在autodl上租卡跑了&#xff0c;autodl有一个网络共享存储&#xff0c;可挂载至同一地区的不同实例中&#xff0c;当我们在该地区创建实例开机后&#xff0c;将会挂载文件存储至实例的/root/autodl-fs目录…

Grafana 安装指南

目录 介绍 安装 卸载 Grafana 汉化 介绍 Grafana是一款开源数据可视化平台&#xff0c;支持连接多种数据源&#xff0c;创建定制化仪表盘&#xff0c;通过直观的查询编辑器分析数据&#xff0c;设置灵活的警报规则并接收通知&#xff0c;具备丰富的插件生态系统&#xff0c…

韩国量子之梦:将量子计算纳入新增长 4.0战略

内容来源&#xff1a;量子前哨&#xff08;ID&#xff1a;Qforepost&#xff09; 编辑丨王珩 编译/排版丨沛贤 深度好文&#xff1a;1500字丨9分钟阅读 据《朝鲜邮报》报道&#xff0c;韩国将推出由量子计算加速的云服务&#xff0c;并在首尔地区启动城市空中交通的试飞&…

微信小程序订阅消息前后端示例

微信小程序的订阅消息&#xff0c; 必须是由弹框&#xff0c;弹框&#xff0c;弹框来调起了&#xff0c;单纯的在页面上调用 wx.requestSubscribeMessage是没有效果的 小程序端的代码 <view class"sub" bindtap"dinyuxiaoxi">订阅消息</view>…

Leetcoder Day27| 贪心算法part01

语言&#xff1a;Java/Go 理论 贪心的本质是选择每一阶段的局部最优&#xff0c;从而达到全局最优。 什么时候用贪心&#xff1f;可以用局部最优退出全局最优&#xff0c;并且想不到反例到情况 贪心的一般解题步骤 将问题分解为若干个子问题找出适合的贪心策略求解每一个子…

【Linux系统化学习】信号概念和信号的产生

目录 信号的概念 从生活中的例子中感知信号 前台进程和后台进程 前台进程 后台进程 操作系统如何知道用户向键盘写入数据了&#xff1f; 进程如何得知自己收到了信号&#xff1f; 信号捕捉 signal函数 Core Dump&#xff08;核心转储&#xff09; 信号产生的方式 通…