新手练习项目 7:猜数字游戏

名人说:莫听穿林打叶声,何妨吟啸且徐行。—— 苏轼《定风波·莫听穿林打叶声》
Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder)

目录

        • 一、项目描述
        • 二、项目实现
        • 三、项目步骤
        • 四、项目扩展方向

更多项目内容,请关注我、订阅专栏《项目探索实验室》,内容持续更新中…

项目名称:猜数字游戏

一、项目描述

创建一个猜数字游戏,玩家需要在限定次数内猜出一个由计算机随机生成的数字

游戏规则如下:

  1. 计算机生成一个1到100之间的随机整数。
  2. 玩家有有限次数(如10次)来猜这个数字。
  3. 每次猜测后,计算机会告诉玩家猜的数字是太大了还是太小了。
  4. 如果玩家在限定次数内猜对,显示胜利信息。
  5. 如果玩家用完所有次数还未猜对,显示失败信息并告知正确数字。
二、项目实现

可以选择简单地用函数来实现这个游戏,也可以定义一个GuessingGame类来封装游戏逻辑。

三、项目步骤
#include <iostream>
#include <cstdlib> // for rand() and srand()
#include <ctime>   // for time()using namespace std;class GuessingGame {
private:int secretNumber;int maxAttempts;int attemptsLeft;void resetGame() {// Seed the random number generatorsrand(static_cast<unsigned int>(time(0)));// Generate a random number between 1 and 100secretNumber = rand() % 100 + 1;attemptsLeft = maxAttempts;}public:GuessingGame(int maxAttempts) : maxAttempts(maxAttempts), attemptsLeft(maxAttempts) {resetGame();}void play() {int guess;char playAgain;do {cout << "欢迎来到猜数字游戏!" << endl;cout << "我已经选择了一个1到100之间的数字。" << endl;cout << "你有 " << maxAttempts << " 次机会来猜它。" << endl;while (attemptsLeft > 0) {cout << "请输入你的猜测:";cin >> guess;if (guess == secretNumber) {cout << "恭喜你!你猜对了这个数字!" << endl;break;} else if (guess < secretNumber) {cout << "太小了!" << endl;} else {cout << "太大了!" << endl;}attemptsLeft--;cout << "剩余次数:" << attemptsLeft << endl;}if (attemptsLeft == 0) {cout << "很抱歉,你已经用完了所有机会。正确的数字是 " << secretNumber << "。" << endl;}cout << "你想再玩一次吗?(y/n):";cin >> playAgain;if (playAgain == 'y' || playAgain == 'Y') {resetGame();}} while (playAgain == 'y' || playAgain == 'Y');cout << "感谢你玩猜数字游戏!再见!" << endl;}
};int main() {int maxAttempts = 10; // 你可以更改尝试次数GuessingGame game(maxAttempts);game.play();return 0;
}
#include "Book.h"
#include <iostream>
#include <vector>
using namespace std;void displayMenu() {cout << "1. 添加图书" << endl;cout << "2. 更新图书信息" << endl;cout << "3. 删除图书" << endl;cout << "4. 查找图书" << endl;cout << "5. 显示所有图书信息" << endl;cout << "6. 退出" << endl;
}void addBook(vector<Book> &books) {string title, author, ISBN;cout << "输入书名: ";cin.ignore();getline(cin, title);cout << "输入作者: ";getline(cin, author);cout << "输入ISBN: ";getline(cin, ISBN);books.push_back(Book(title, author, ISBN));
}void updateBook(vector<Book> &books) {string ISBN, title, author, newISBN;cout << "输入要更新的图书的ISBN: ";cin.ignore();getline(cin, ISBN);for (Book &book : books) {if (book.getISBN() == ISBN) {cout << "输入新书名: ";getline(cin, title);cout << "输入新作者: ";getline(cin, author);cout << "输入新ISBN: ";getline(cin, newISBN);book.update(title, author, newISBN);return;}}cout << "未找到该ISBN的图书。" << endl;
}void deleteBook(vector<Book> &books) {string ISBN;cout << "输入要删除的图书的ISBN: ";cin.ignore();getline(cin, ISBN);for (auto it = books.begin(); it != books.end(); ++it) {if (it->getISBN() == ISBN) {books.erase(it);return;}}cout << "未找到该ISBN的图书。" << endl;
}void findBook(const vector<Book> &books) {string ISBN;cout << "输入要查找的图书的ISBN: ";cin.ignore();getline(cin, ISBN);for (const Book &book : books) {if (book.getISBN() == ISBN) {book.display();return;}}cout << "未找到该ISBN的图书。" << endl;
}void displayAllBooks(const vector<Book> &books) {for (const Book &book : books) {book.display();}
}int main() {vector<Book> books;int choice;while (true) {displayMenu();cin >> choice;switch (choice) {case 1:addBook(books);break;case 2:updateBook(books);break;case 3:deleteBook(books);break;case 4:findBook(books);break;case 5:displayAllBooks(books);break;case 6:return 0;default:cout << "无效选项,请重新选择。" << endl;}}return 0;
}

效果如图:

image-20240630164032219

四、项目扩展方向

可以根据需要扩展项目,例如:

  • 增加难度选择(如选择猜测范围或最大次数)。
  • 增加一个计分系统,根据猜测次数和成功与否来评分。

Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder)
点赞加关注,收藏不迷路!本篇文章对你有帮助的话,还请多多点赞支持!

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

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

相关文章

comsol学习笔记

comsol岩土力学与流固耦合的学习 comsol的相关视频教程 https://www.bilibili.com/video/BV1Cu4y1r7Gn/?spm_id_from333.337.search-card.all.click&vd_source02b2bad477a153eaeb9c48cbbedaf8df [这里面有讲解地应力平衡技术] https://www.bilibili.com/video/BV17C4y1j…

打靶记录——靶机medium_socnet

靶机下载地址 https://www.vulnhub.com/entry/boredhackerblog-social-network,454/ 打靶过程 由于靶机和我的Kali都处于同一个网段&#xff0c;所以使用arpscan二次发现技术来识别目标主机的IP地址 arpscan -l除了192.168.174.133&#xff0c;其他IP都是我VMware虚拟机正…

【Spring Boot】认识 JPA 的接口

认识 JPA 的接口 1.JPA 接口 JpaRepository2.分页排序接口 PagingAndSortingRepository3.数据操作接口 CrudRepository4.分页接口 Pageable 和 Page5.排序类 Sort JPA 提供了操作数据库的接口。在开发过程中继承和使用这些接口&#xff0c;可简化现有的持久化开发工作。可以使 …

springboot学习,如何用redission实现分布式锁

目录 一、springboot框架介绍二、redission是什么三、什么是分布式锁四、如何用redission实现分布式锁 一、springboot框架介绍 Spring Boot是一个开源的Java框架&#xff0c;由Pivotal团队&#xff08;现为VMware的一部分&#xff09;于2013年推出。它旨在简化Spring应用程序…

大数据面试题之Spark(1)

目录 Spark的任务执行流程 Spark的运行流程 Spark的作业运行流程是怎么样的? Spark的特点 Spark源码中的任务调度 Spark作业调度 Spark的架构 Spark的使用场景 Spark on standalone模型、YARN架构模型(画架构图) Spark的yarn-cluster涉及的参数有哪些? Spark提交jo…

横穿自动驾驶

如果有一条线&#xff0c;可以穿起来所有自动驾驶的核心模块&#xff0c;那么我感觉它就是最优化&#xff0c;选择优化变量、构造优化问题、求解优化问题&#xff0c;这几个步骤贯穿了自动驾驶的始终。 先从我的自身接触顺序写起。最开始做个一点深度学习&#xff0c;那还是20…

编码大模型系列:Meta创新的“代码编译优化”的LLM

鲁班号导读正式上线。移步“鲁班秘笈”&#xff0c;查阅更多内容。 大型语言模型 (LLM) 已在各种软件工程和编码任务中展现出卓越的能力。然而&#xff0c;它们在代码和编译器优化领域的应用仍未得到充分探索。训练LLM需要大量资源&#xff0c;需要大量的 GPU时间和大量的数据…

23、架构-服务网格之透明通信涅槃

通信成本 在现代分布式系统中&#xff0c;服务之间的通信是不可避免的。然而&#xff0c;这种通信带来了额外的复杂性和成本。传统的通信方式如RPC&#xff08;Remote Procedure Call&#xff09;和REST&#xff08;Representational State Transfer&#xff09;&#xff0c;虽…

Hive 实操案例五:统计每个类别中 Top10 的视频热度

一、数据表结构 视频表 t_video 字段注释描述videoId视频唯一 id&#xff08;String&#xff09;11 位字符串uploader视频上传者&#xff08;String&#xff09;上传视频的用户名 Stringage视频年龄&#xff08;int&#xff09;视频在平台上的整数天category视频类别&#xff0…

一个合理的前端应用文件结构

在大型应用中&#xff0c;最关键且最具挑战性的方面之一就是拥有一个良好且合理的文件结构。在考虑通过微前端将代码库拆分成多个应用之前&#xff0c;可以遵循一些步骤来改善项目级别的架构&#xff0c;并在您考虑这一路径时使过渡更容易。 我们的目标是应用某种模块化方法&am…

MSPM0G3507——定时器例程讲解4——timx_timer_mode_periodic

以下示例以周期模式配置TimerG并切换LED。周期从500ms开始&#xff0c;每次切换减少50ms&#xff0c;直到周期为100ms&#xff0c;然后重复。设备在等待中断时保持待机模式 #include "ti_msp_dl_config.h"/* ((32KHz / (321)) * 0.5s) 45 - 1 495 due to N1 ticks …

MySQL入门学习-MySQL日志.错误日志

错误日志是 MySQL 中一种记录服务器运行过程中错误信息的日志文件。它可以帮助管理员或开发人员快速定位和解决问题。 一、MySQL 中的错误日志具有以下特点&#xff1a; - 记录错误信息&#xff1a; 错误日志主要记录服务器在运行过程中发生的错误信息&#xff0c;包括但不限…

【算法 之选择排序 原理及案例】

选择排序&#xff08;Selection Sort&#xff09; 是一种简单直观的排序算法。它的工作原理是&#xff1a;首先在未排序序列中找到最小&#xff08;或最大&#xff09;元素&#xff0c;存放到排序序列的起始位置&#xff0c;然后&#xff0c;再从剩余未排序元素中继续寻找最小…

Memcached的API使用指南:常用操作与示例代码

Memcached 是一个高性能、分布式内存对象缓存系统&#xff0c;常用于加速动态Web应用程序&#xff0c;减轻数据库负载。本文将介绍如何使用Memcached的API进行常用操作&#xff0c;并提供示例代码。 1. 安装Memcached客户端库 在使用Memcached之前&#xff0c;需要安装相应的…

Qt中用QLabel创建状态灯

首先ui设计中分别创建了4个大灯和4个小灯。 编辑.h文件 #ifndef LED_H #define LED_H#include <QWidget> #include <QLabel>QT_BEGIN_NAMESPACE namespace Ui { class Led; } QT_END_NAMESPACEclass Led : public QWidget {Q_OBJECTpublic:Led(QWidget *parent n…

Spring MVC数据绑定和响应——复杂数据绑定(四)JSON数据绑定

一、消息转换器—HttpMessageConverter接口 客户端不同的请求&#xff0c;HttpServletRequest中数据的MediaType可能会不同&#xff0c;如果想将HttpServletRequest中的数据转换成指定对象&#xff0c;或者将对象转换成指定格式的数据&#xff0c;就需要使用对应的消息转换器来…

服务器硬件以及RAID配置

目录 一、RAID磁盘阵列原理&#xff08;嘎嘎重要&#xff09; 1、RAID的概述 2、常用的RAID 2.1、RAID 0 2.2、RAID 1 2.3、RAID 5 2.5、RAID 10 3、阵列卡介绍 二、建立软件RAID磁盘阵列 1、添加硬盘 2、使用fdisk分区&#xff0c;类型为fd 3、mdata命令使用参数 …

安全与加密常识(3)什么是数字签名和数字证书

文章目录 数字签名工作原理关键特点应用实例 数字证书数字证书和数字签名趣味实例 数字签名 数字签名是一种通过密码运算生成的数据&#xff0c;用于验证信息的完整性和来源&#xff0c;确保数据在传输过程中未被篡改&#xff0c;同时提供发送者的身份认证和防止抵赖的功能。它…

Qt: QPushButton 按钮实现 上图标下文字

效果如下&#xff1a; 实现有如下几种方式&#xff1a; 1. 使用 QPushButton 设置 setStyleSheet 例&#xff1a; ui->recorder->setStyleSheet("QPushButton{"\"border: 1px solid #00d2ff; "\"min-height: 60px; "\"col…

python多继承的3C算法

python多继承的3C算法 有很多地方都说python多继承的继承顺序&#xff0c;是按照深度遍历的方式&#xff0c;其实python多继承顺序的算法&#xff0c;不是严格意义上的深度遍历&#xff0c;而是基于深度遍历基础上优化出一种叫3C算法 python多继承的深度遍历 class C:def ru…