C++恶魔轮盘赌(道具版)

2024-04-20 20:04
文章标签 c++ 轮盘 恶魔 道具

本文主要是介绍C++恶魔轮盘赌(道具版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

家人们,更新了昂,前文:来自阳了个阳C++的恶魔轮盘赌无道具版

作为阳了个阳C++的好同学,我光荣地揽下了道具版的重担

不多说话,直接上代码

#include<bits/stdc++.h>
#include<Windows.h>
typedef long long ll;
using namespace std;
enum TOOLS {SMOKE,HAND_C,MAGNIFYING_GALSS,KNIFE,DRINKS
};
struct PLAYER_INFO {ll life;ll tls[5];
} player,dealer;
ll emp_bullets,tru_bullets,nw,nw_damage=1;
vector<ll> Bullets;
bool now_gun=1,nxt_gun=0;
void Introduction();
ll R(ll left_boundary,ll right_boundary);
void GiveOutTools();
void printOutTools();
void Init_Bullets();
bool Round();
void Do_Dealer_AI();
int main() {srand(time(NULL));Introduction();Init_Bullets();GiveOutTools();while(Round()) {ll a,b;a=b=0;cout<<"  你 剩余血量"<<player.life<<"滴\n";cout<<"对手 剩余血量"<<dealer.life<<"滴\n";for(ll i=nw;i<Bullets.size();i++)if(Bullets[i]) a++;else b++;cout<<"剩余"<<a<<"发实弹和"<<b<<"发空弹\n";if(nw>Bullets.size()) Init_Bullets(),GiveOutTools();Sleep(2000);system("cls");}return 0;
}
void Introduction() {system("color 4");cout<<"欢迎来到恶魔轮盘赌\n";cout<<"我是你的对手\n";Sleep(2000);system("cls");cout<<"请输入每轮真弹数量,假弹数量,以及电量格数\n";cin>>tru_bullets>>emp_bullets>>player.life;dealer.life=player.life;system("cls");
}
ll R(ll left_boundary,ll right_boundary) {return rand()%(right_boundary-left_boundary)+left_boundary;
}
void Init_Bullets() {ll e=emp_bullets,t=tru_bullets;while(e+t) {ll x=rand()%2;if(!x) {if(e) {e--;Bullets.push_back(x);} else {t--;Bullets.push_back(1);}} else {if(t) {t--;Bullets.push_back(x);} else {e--;Bullets.push_back(0);}}}
}
void GiveOutTools() {ll r=R(2,4);for(ll i=1; i<=2; i++)for(ll k=1; k<=r; k++) {ll tr=R(0,4);if(i==1) player.tls[tr]++;else dealer.tls[tr]++;}
}
void printOutTools() {cout<<"华子"<<player.tls[0]<<"个\n手铐"<<player.tls[1]<<"个\n放大镜"<<player.tls[2]<<"个\n小刀"<<player.tls[3]<<"个\n饮料"<<player.tls[4]<<"个\n";cout<<"手铐同一轮不可叠加,小刀伤害不可叠加\n";
}
bool Round() {if(now_gun) {cout<<"输入1使用道具\n输入2直接开枪\n请选择:";printOutTools();ll slt;cin>>slt;while(slt!=1&&slt!=2) cin>>slt;if(slt==1) {
ReUse:system("cls");printOutTools();cout<<"请按顺序输入道具使用序列,道具之间空格隔开\n";string Use_tls;vector<string> nd_use_tls;cin.get();getline(cin,Use_tls);Use_tls+=" ";string getStr,emp;for(ll i=0; i<Use_tls.size(); i++)if(Use_tls[i]!=' ') getStr+=Use_tls[i];else {nd_use_tls.push_back(getStr);getStr=emp;}for(auto xx:nd_use_tls) {if(xx=="华子") if(player.tls[0]) player.tls[0]--,player.life++;if(xx=="手铐") if(player.tls[1]) player.tls[1]--,nxt_gun=1;if(xx=="放大镜") if(player.tls[2]) {player.tls[2]--;cout<<"当前子弹为:"<<(Bullets[nw]?"实弹":"空弹")<<"\n";}if(xx=="小刀") if(player.tls[3]) {nw_damage=min(nw_damage*2,(ll)2);player.tls[3]--;}if(xx=="饮料") if(player.tls[4]) {nw++;cout<<"退出了一发"<<(Bullets[nw-1]?"实弹":"空弹")<<"\n";player.tls[4]--;}}cout<<"qwq道具用好啦,";}cout<<"你要向谁开枪(1表示自己,2表示对手,3表示还要用道具):";cin>>slt;while(slt!=1&&slt!=2&&slt!=3) cin>>slt;if(slt==3) goto ReUse;if(slt==1) {if(Bullets[nw]==1) {cout<<"是实弹,你扣血了,扣了"<<nw_damage<<"滴,剩余"<<player.life-nw_damage<<"滴血\n";player.life-=nw_damage;if(player.life<=0) {cout<<"你挂了\n";exit(0);}now_gun=nxt_gun;nxt_gun=!nxt_gun; } else {cout<<"是空弹,下一轮还是你\n";nxt_gun=1;now_gun=nxt_gun;nxt_gun=0;}} else {if(Bullets[nw]==1) {cout<<"是实弹,对手扣血"<<nw_damage<<"滴,剩余"<<dealer.life-nw_damage<<"滴血\n";dealer.life-=nw_damage;if(dealer.life<=0) {cout<<"对手挂了\n";exit(0);}now_gun=nxt_gun;nxt_gun=!nxt_gun; } else {cout<<"是空弹\n";now_gun=nxt_gun;nxt_gun=!nxt_gun;}}nw++;nw_damage=1;} else {Do_Dealer_AI();}return true;
}
void Do_Dealer_AI() {while(dealer.tls[0]) {dealer.life++;dealer.tls[0]--;}if(dealer.tls[1]) if(nxt_gun) {nxt_gun=0;dealer.tls[1]--;}if(dealer.tls[2]) {int gt=Bullets[nw];if(!gt) {cout<<"对手向自己开枪,是空弹\n";now_gun=0,nxt_gun=1;} else {cout<<"对手";if(dealer.tls[3]) {nw_damage=2;dealer.tls[3]--;cout<<"用小刀后";}cout<<"向你开枪\n";player.life-=nw_damage;nw++;cout<<"你剩"<<player.life<<"滴血\n";if(player.life<=0) {cout<<"你挂了\n";exit(0);}}} else {int rnd=rand()%3+1;if(rnd<3) {cout<<"对手向你开枪,是"<<(Bullets[nw]?"实弹":"空弹")<<"\n";if(Bullets[nw]) {nw++;player.life--;cout<<"你剩"<<player.life<<"滴血\n";if(player.life<=0) {cout<<"你挂了\n";exit(0);}now_gun=nxt_gun;nxt_gun=!nxt_gun;} else {nw++;now_gun=nxt_gun;nxt_gun=!nxt_gun;}} else {int b=Bullets[nw];cout<<"对手向自己开枪,是"<<(b?"实弹\n":"空弹\n");if(b) {nw++;dealer.life--;cout<<"对手剩"<<dealer.life<<"滴血\n";if(dealer.life<=0) {cout<<"对手挂了\n";exit(0);}now_gun=nxt_gun;nxt_gun=!nxt_gun;} else {nw++;now_gun=0,nxt_gun=1;}}}
}

耗时2周,手撸的代码,誊抄在电脑上的,创作不易,在下跪求点赞+关注啊!

这篇关于C++恶魔轮盘赌(道具版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/921198

相关文章

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快