C++大学教程(第九版)6.48掷骰子游戏的改进

2024-01-26 12:52

本文主要是介绍C++大学教程(第九版)6.48掷骰子游戏的改进,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目
  • 代码
  • 运行截图

题目

(掷骰子游戏的改进)请修改图6.11 中的双游戏序允许家下赌注。
把序中运行掷骰子游戏的部分打包为一个函数。
初始化变量 bankBalance 为 1000美元。
提示玩家输入赌注数:wager。
利用一个 while 循环来检查 wager 是否小于或等于 bankBalance。
如果不是,则提示用户重新输人 wager 直到输人一个合法的 wager 值。

输人了一个正确的 wager 值以后,运行掷子游戏如果玩家获胜,bankBalance 的值增加 wager,并且打印出新的 bankBalance 值。
如果玩家输了bankBalance 将减去 wager,打印新的 bankBalance 的值并且检查它的值是否已变为0;如果是则打印消息“Sorry. You busted!”。
在游戏的进行过程中,应该打印出各种各样的消息,增添点“聊天”效果,诸如一些“小对话”:“Oh,you’re going for broke,huh?”,“Aw cmon,take a chance!”,或者“You’re up big. Now’s the time to cash in your chips!”

代码

// 掷双骰游戏改进
#include <iostream>
#include <cstdlib>
#include <ctime>using namespace std;unsigned int rollDice();//掷骰子
bool gameRollDice();//掷骰子游戏int main()
{unsigned int bankBalance = 1000;unsigned int wager;cout << "Please enter the wager:";//请输入赌注cin >> wager;while (wager > bankBalance){cout << "Your wager is invalid.\nPlease re-enter the wager:";cin >> wager;}cout << "Aw, cmon, take a chance!" << endl; // 来吧,抓住机会if (gameRollDice()){bankBalance = bankBalance + wager; // 玩家赢了cout << "Bank Balance is " << bankBalance;}else{bankBalance = bankBalance - wager; // 玩家输了cout << "Bank Balance is " << bankBalance;}if (0 == bankBalance){cout << "Sorry. You busted! " << endl;               // 你搞砸了cout << "Oh, you are going for broke, huh?" << endl; // 你要破产了}return 0;
}unsigned int rollDice() // 掷骰子
{unsigned int die1 = 1 + rand() % 6;unsigned int die2 = 1 + rand() % 6;unsigned int sum = die1 + die2;cout << "Player rolled " << die1 << " + "<< die2 << " = " << sum << endl;return sum;
}bool gameRollDice() // 掷骰子游戏
{enum Status{CONTINUE,WON,LOST}; // 用来表示游戏状态srand(static_cast<unsigned int>(time(0))); // 随机数的种子unsigned int myPoint = 0; // 用于后续几轮的状态记录Status gameStatus = CONTINUE;        // 记录当前的游戏状态,控制结束的关键unsigned int sumOfDice = rollDice(); /// 记录第一次掷的结果// 决定当前的游戏状态switch (sumOfDice){case 7:case 11: // 第一次掷到和为7或11,游戏胜利gameStatus = WON;break;case 2:case 3:case 12: // 第一次掷到和为2,3,12,游戏失败gameStatus = LOST;break;default:gameStatus = CONTINUE;myPoint = sumOfDice; // 记录下自己后续几轮的目标点数cout << "Point is " << myPoint << endl;break;}while (CONTINUE == gameStatus){sumOfDice = rollDice();if (sumOfDice == myPoint){gameStatus = WON;}else if (7 == sumOfDice){gameStatus = LOST;}}if (WON == gameStatus)return true;elsereturn false;
}

运行截图

在这里插入图片描述
在这里插入图片描述

这篇关于C++大学教程(第九版)6.48掷骰子游戏的改进的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者