从入门到精通,30天带你学会C++【第十天:猜数游戏】

目录

Everyday English

前言

实战1——猜数游戏

综合指标

游玩方法

代码实现

最终代码

试玩时间 

必胜策略

具体演示

结尾


Everyday English

All good things come to those who wait.

时间不负有心人

前言

今天是2024年的第一天,新一年,新气象,新起点,在这也祝愿大家:

工作顺利,身体健康。好好学习,天天向上!

实战1——猜数游戏

综合指标

学了10天左右,是不是很想做一款小游戏,那么今天它来了!

猜数游戏是初学者很好的一个实战项目,下面是它的全面分析:

编程难度:★★

有趣程度:★★

游戏难度:★★★

编程时间:推荐5min~12min

游玩方法

首先电脑会在1-100中随机生成一个整数,玩家需在1-100中猜一个数字,分三种情况讨论。

1.玩家猜的数字>目标数字,电脑说:“大了”

2.玩家猜的数字<目标数字,电脑说:“小了”

3.玩家猜的数字=目标数字,电脑说:“恭喜您,猜对啦!”

这时你可能会问:“这么简单的游戏难度为什么是3颗星呢?”

真相只有一个,那就是:

你只有7次猜的机会!

这下你可能就慌了,啊,100个数呢!就7次哪够啊!!!

到底够不够呢,我们稍后揭晓。

代码实现

原神,启动!Bi----------------

搞错了,重来!

代码,启动!这下对了。

首先,电脑需要随机生成一个1-100以内的整数,我们用key来保存这个随机整数:

srand(time(NULL));
int key=rand()%100+1;

大家可能还不知道随机数是怎么用的,我来教大家一下。程序中的第一行是播随机数种子,也称“播种”,每次生成随机数时带上他就好了。

第二行中的rand就是一个随机函数,我们想一想一个数对100取余,结果只可能是:0,1,2......,99。

可我们想要的是1-100,所以我们可以让每项都加一即可。

接着我们来分析一下如何实现玩家能猜7次数,这里需要用到我们的for循环语句:

for(int i=1;i<=7;i++)
{//当猜的数小于key时//当猜的数大于key时//当猜的数等于key时
}

每循环一次,玩家首先要去猜一个数,我们说的三种情况都可以用简单的if语句实现: 

for(int i=1;i<=7;i++)
{int x;cin>>x;//当猜的数小于key时if(x<key){cout<<"小了"<<endl;} //当猜的数大于key时if(x>key){cout<<"大了"<<endl;} //当猜的数等于key时if(x==key){cout<<"恭喜您,猜对啦!"<<endl;} 
}

 最后加上7次内没猜对的提示语,并把代码拼在一起,得到了以下程序:

#include<bits/stdc++.h>
using namespace std;
int main()
{srand(time(NULL));int key=rand()%100+1;for(int i=1;i<=7;i++){int x;cin>>x;//当猜的数小于key时if(x<key){cout<<"小了"<<endl;} //当猜的数大于key时if(x>key){cout<<"大了"<<endl;} //当猜的数等于key时if(x==key){cout<<"恭喜您,猜对啦!"<<endl;return 0; } }cout<<"7次机会已用完,很遗憾,未猜对!"<<endl;
}

最终代码

当然我们还可以优化一下提示语,便得到了最终代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{cout<<"猜数游戏(1-100)"<<endl;srand(time(NULL));int key=rand()%100+1;for(int i=1;i<=7;i++){int x;cout<<"请输入一个数字:";cin>>x;//当猜的数小于key时if(x<key){cout<<"小了"<<endl;} //当猜的数大于key时if(x>key){cout<<"大了"<<endl;} //当猜的数等于key时if(x==key){cout<<"恭喜您,猜对啦!"<<endl;return 0; } }cout<<"7次机会已用完,很遗憾,未猜对!"<<endl;cout<<"正确数字是:"<<key<<endl;return 0;
}

试玩时间 

做完程序大家一定要自己玩一玩看看有没有什么错误。

我的运气有亿点点“好”,大家赶紧去试试吧!

必胜策略

悄悄告诉你,这个游戏也有必胜策略哦!

这个策略有个好听的名字叫——二分法

顾名思义,每次猜区间的一半,那我们先计算一下,利用二分法第一次该猜几呢?

对了是50!如果计算机说小了又该猜几呢?

对了是75!(100-50)÷2+50=75!

注意:除不尽的话四舍五入!

具体演示

 

所以,如果你想有趣一点,加点运气成分的话,

你可以把猜的次数调成6次,或者更少!

结尾

想不到吧,一个小小的猜数游戏都被我们玩得那么细,如果你不介意的话,能否给我点一个小小的赞或者评论支持一下呢?

最后认识一下,我是爱编程的小芒果,一个爱编程的小学生,我们2024年见!

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

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

相关文章

深入理解和运用C语言中的Break语句

各位少年 尊敬的读者们&#xff0c; 在C语言编程中&#xff0c;控制程序流程是我们编写高效代码的关键。今天&#xff0c;我们将一起探讨一种能够立即终止循环或开关语句的关键字——Break。 一、理解Break语句 Break关键字在C语言中用于立即退出当前的循环&#xff08;如f…

【网络】修改网口名字|网络设备|网口管理

目录 系统的网口(网络设备)命名规则 修改网口(网络设备)命名 永久修改 临时修改 使用传统eth0、eth1的命名方式 注意事项 系统的网口(网络设备)命名规则 ens35f0 这个名称是基于 Linux 的网络接口命名规则生成的。 在较新的 Linux 发行版中&#xff0c;网络接口的命名规…

LC106. 从中序与后序遍历序列构造二叉树

参考&#xff1a;代码随想录 class Solution {Map<Integer,Integer> map ;public TreeNode buildTree(int[] inorder, int[] postorder) {map new HashMap<>();for(int i 0 ; i < inorder.length; i ){map.put(inorder[i],i);}return findNode(inorder,0,inor…

计算机毕业设计——springboot养老院管理系统 养老院后台管理

1&#xff0c;绪论 1.1 背景调研 养老院是集医疗、护理、康复、膳食、社工等服务服务于一体的综合行养老院&#xff0c;经过我们前期的调查&#xff0c;院方大部分工作采用手工操作方式,会带来工作效率过低&#xff0c;运营成本过大的问题。 院方可用合理的较少投入取得更好…

声明式导航传参详情

1 动态路由传参 路由规则path ->/article/:aid 导航链接 <router-link to"/article/1">查看第一篇文章</router-link> 组件获取参数: this.$route.params.aid 如果想要所有的值&#xff0c;就用this. $route. params 注意&#xff1a;这两个必须匹配…

Spring Cloud Function SpEL注入漏洞(CVE-2022-22963)分析

一、概述 2022年3月24日&#xff0c;Pivotal修补了Spring Cloud Function中一个关键的服务器端代码注入漏洞&#xff08;Spring表达式语言注入&#xff09;&#xff0c;该漏洞有可能导致系统被攻击。Spring是一种流行的开源Java框架&#xff0c;该漏洞与另一个相关的远程代码执…

Dirichlet Process (徐亦达老师)狄利克雷过程

混合高斯模型的例子 混合高斯模型 混合高斯模型&#xff08;Mixture of Gaussians&#xff0c;简称GMM&#xff09;是一种概率模型&#xff0c;用于对复杂的数据分布进行建模。它是由多个高斯分布组合而成的混合模型&#xff0c;每个高斯分布&#xff08;称为组件&#xff09;…

86 滑动窗口判断是否有重复元素II

问题描述&#xff1a;给定一个整数数组和一个整数k&#xff0c;判断数组中是否存在两个不同的索引i和j&#xff0c;使得nums[i]nums[j],并且i和j的绝对值最多为k。 map求解&#xff1a;首先将第一个元素放入map中&#xff0c;因为它不可能与任何一个元素构成队列&#xff0c;然…

HJ108 求最小公倍数

题目&#xff1a; HJ108 求最小公倍数 题解&#xff1a; 辗转相除法求出最大公约数&#xff0c;然后求出最小公倍数。 public int gcd(int a, int b) {if (b 0) {return a;}return gcd(b, a%b);} 时间复杂度&#xff1a;O(N)

基于SpringBoot的职业生涯规划系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的职业生涯规划系统,java…

知识库问答LangChain+LLM的二次开发:商用时的典型问题及其改进方案

前言 如之前的文章所述&#xff0c;我司下半年成立大模型项目团队之后&#xff0c;我虽兼管整个项目团队&#xff0c;但为让项目的推进效率更高&#xff0c;故分成了三大项目组 第一项目组由霍哥带头负责类似AIGC模特生成系统第二项目组由阿荀带头负责论文审稿GPT以及AI agen…

pytorch深度学习笔记(共计169页,基于本人听完B站小土堆PyTorch深度学习快速入门教程所写)

一、笔记视频 pytorch深度学习&#xff08;共计169页&#xff0c;基于本人听完B站小土堆PyTorch深度学习快速入门教程所写&#xff09; 二、获取方式 方式一&#xff1a; 点击下面的链接 pytorch深度学习笔记 如果链接无法打开 直接复制下方链接即可 https://mall.bilibili.c…

如何借助边缘网关打造智慧配电房安全方案

配电房是电力系统的重要组成部分&#xff0c;通常设置有各种高压配电装置和箱柜&#xff0c;是企业安全管理的重点。传统的人工巡检和监控总是难以避免疏漏&#xff0c;导致风险隐患的产生和扩大。 随着物联网、边缘计算、设备联动控制等技术的普及应用&#xff0c;佰马针对配电…

在FC中手工创建虚拟机模板

1、Linux去除个性化信息 &#xff08;1&#xff09;编辑网卡配置文件&#xff0c;只保留以下内容&#xff08;以RHEL 7为例&#xff09; &#xff08;2&#xff09;清除主机密钥信息&#xff08;开机会自动生成&#xff09; &#xff08;3&#xff09;清除Machine ID&#xff…

机器学习概述

最近在学习机器学习的基础知识&#xff0c;在此记录一下 目前最火的机器学习框架是Scikit-Learn和pytorch&#xff0c;因此&#xff0c;之后的一段时间会使用这两种框架搭建机器学习的模型&#xff0c;相应的学习资源也会开源&#xff0c;希望可以学习到很多知识。 简单介绍机…

(C)一些题21

1.条件语句 while(x){...}中条件表达式 x 的等价写法是 B。 A. x0 B. x!0 C. x1 D. x!1 2.表达式 1!2 && 35 的值是 C。 A. True B. False C. 0 D. 1 3。. _______125__________。 #include <stdio.h> int x; void main() { x5; cude(); printf("%d\n"…

Servlet见解3

13 Cookie和Session http协议是一个无状态的协议&#xff0c;你每一个跳转到下一个页面的时候都是需要先登录才能使用&#xff0c;这样就很麻烦比如淘宝&#xff0c;没有cookie和session的话&#xff0c;用户在首页已经登录上去了&#xff0c;但是需要再次登录才能选择商品&am…

计算几何库

1、Geos GEOS 是一个用于计算几何的C/C库&#xff0c;专注于地理信息系统(GIS) 软件中使用的算法。它实现了OGC 简单特征几何模型&#xff0c;并提供了该标准以及许多其他标准中的所有空间功能。GEOS 是PostGIS、QGIS、GDAL和Shapely的核心依赖项。 它旨在包含C 中JTS的完整功…

Linux: dev: glibc: GL 定义

今天找到了这个GL的定义&#xff0c;记录一下&#xff0c;费了一些劲才找到的。&#xff08;没有想到的是#和define之间还有空格&#xff0c;导致一直搜不到想要的结果。&#xff09;是在sysdeps/generic/ldsodefs.h文件中。依赖于SHARED和rtld的定义。 #ifndef SHARED # defi…

嵌入式Linux C语言介绍

目录 一.前言 二.C语言的特点 一.前言 开发工具通常依赖于操作系统提供的各种功能和服务。许多开发工具都基于操作系统的API&#xff08;应用程序接口&#xff09;进行开发&#xff0c;这些API提供了文件处理、网络通信、图形界面等核心功能。没有操作系统的支持&#xff0c;…