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 的框架更轻量和更快内置功能包括快捷方式传递、沉浸…

小程序中使用echarts地图

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

【Linux】协程简介

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

机器学习 | 模型评估和选择 各种评估指标总结——错误率精度-查准率查全率-真正例率假正例率 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…

【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…

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

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

韩国量子之梦:将量子计算纳入新增长 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; 信号产生的方式 通…

LeetCode 刷题 [C++] 第102题.二叉树的层序遍历

题目描述 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 题目分析 题目中要求层序遍历二叉树&#xff0c;即二叉树的广度优先搜索(BFS)。BFS一般使用队列的先入先出特性实现&#…

react倒计时功能

目录 类组件写法 函数组件写法&#xff1a; demo: 手机获取验证码登录&#xff08;验证码60秒倒计时&#xff09; react倒计时5 秒 React中的倒计时可以通过使用setInterval()函数来实现。下面是一个示例代码&#xff1a; 类组件写法 import React from react; import { But…

【Docker】狂神说

图片后补 官网&#xff1a; https://www.docker.com/ Docker概述 Docker为什么出现 原因&#xff1a;环境配置不能跨平台 方案 传统方式&#xff1a;jar&#xff08;开发人员&#xff09; 部署&#xff08;运维人员&#xff09; 解决方式&#xff1a;开发打包上线一套流程 …

Qt SQLite的创建和使用

重点&#xff1a; 1.SQLite创建数据库内容方法 链接&#xff1a;SQLite Expert Personal的简单使用-CSDN博客 2.和数据库进行链接方法 QSqlDatabase DB; //数据库连接bool MainWindow::openDatabase(QString aFile) {DBQSqlDatabase::addDatabase("QSQLITE"); /…

使用uniapp开发时自定义tabbar

预览图&#xff1a; 一、配置page.jsong中的tabbar&#xff08;这一步是必须的&#xff0c;因为我们在使用uni.switchTab()时必须要用到&#xff09; "tabBar": {"list": [{"pagePath": "pages/index/index","iconPath": &…

java回顾总结--代理模式

目录 一、代理模式1.1 静态代理示例 1.2 动态代理示例 二、总结 一、代理模式 1.1 静态代理 代理模式给某一个对象提供一个代理对象&#xff0c;并由代理对象控制对原对象的引用。通俗的来讲代理模式就是我们生活中常见的中介。比如你按照小卡片上的电话打过去寻求服务&#…

C# 学习第四弹——字符串

一、char类型的使用 字符使用单引号&#xff0c;单个字符 转义字符是一种特殊的字符变量&#xff0c;以反斜线开头&#xff0c;后跟一个或多个字符。 输出多级目录可以使用 二、字符串的声明和初始化 1、引用字符串常量 引用字符串常量初始化——字符使用单引号&#xff0…

加密与安全_探索常用编码算法

文章目录 概述什么是编码编码分类ASCII码 &#xff08;最多只能有128个字符&#xff09;Unicode &#xff08;用于表示世界上几乎所有的文字和符号&#xff09;URL编码 &#xff08;解决服务器只能识别ASCII字符的问题&#xff09;实现&#xff1a;编码_URLEncoder实现&#xf…

K8S常用kubectl命令汇总(持续更新中)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…