文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C++小游戏教程之猜数游戏的实现

2022-11-13 19:25

关注

0. 引言

本章主要讲解如何做一个简易的猜数游戏,分为用户猜数和系统猜数。

前置芝士:

「C++小游戏教程」基本技巧(1)——随机化

1. 用户猜数

系统想好一个在 [ 1 , 100 ] [1,100][1,100] 之间的整数,由用户来猜数,而系统只能回答“过大”“过小”“正确”。

1-1. 设置答案数与猜测数

使用随机数来随机一个 [ 1 , 100 ] [1,100][1,100] 的整数,猜测数初始设置为 − 1 -1−1。

srand(time(0));
int x=-1,ans=rand()%100+1;

1-2. 系统说明要求与读入数字

让系统讲清楚每次猜的数字的范围。
然后就直接让用户输入数字。

printf("I have a number from 1 to 100. Please have a guess: ");
scanf("%d",&x);

1-3. 累计猜测次数与判断数字

记一个变量tms,每次加一。

判断分为四种情况:

1.当x∉[1,100] 时,抛出错误。

if(x<1||x>100) puts("The number is error.");

2.当x>ans 时,说明数字过大,输出。

else if(x>ans) puts("The number is larger than my number!");

3.当x<ans 时,类似,数字过小,输出。

else if(x<ans) puts("The number is smaller than my number!");

4.当x=ans 时,正确,提示输出。

else puts("Oh, you are right!");

外层的循环条件,只要x≠ans时,就执行。

while(x!=ans)
{
    ...
}

1-4. 输出猜测次数

输出tms 并终止。

printf("You guessed it %d times.",tms);

完整代码:

#include<bits/stdc++.h>
using namespace std;

int main()
{
	srand(time(0));
	int x=-1,ans=rand()%100+1,tms=0;
	while(x!=ans)
	{
		printf("I have a number from 1 to 100. Please have a guess: ");
		scanf("%d",&x);
		tms++;
		if(x<1||x>100) puts("The number is error.");
		else if(x>ans) puts("The number is larger than my number!");
		else if(x<ans) puts("The number is smaller than my number!");
		else puts("Oh, you are right!");
	}
	printf("You guessed it %d times.",tms);
 	return 0;
}

效果:

2. 系统猜数,但是是进化史

用户想好一个[1,100] 范围的数,让系统猜。太大输入L,太小输入S,正确输入R。

有了上面的操作,我们让系统猜,写起来整体还是很简单的,但是要让系统聪明些。

先摆出程序框架:

#include<bits/stdc++.h>
using namespace std;

int main()
{
	srand(time(0));
	puts("Please think a number from 1 to 100. And then I'll guess it.");
	puts("If I guess right, you should say \"R\"(Right).");
	puts("If my guess is too large, you should say \"L\"(Large).");
	puts("If my guess is too small, you should say \"S\"(Small).");
	puts("DON'T TELL A LIE!\n");
	char c='\0';
	int tms=0;
	while(c!='R')
	{
		//...
		printf("I guess the number is %d.Is it right(R, L or S)? ",);
		scanf("%c%*c",&c);
		tms++;
		if(c=='R') break;
		//...
	}
	printf("I guess it %d times!",tms);
 	return 0;
}

2-1. 代码 v1.0——我会瞎猜!

系统只会瞎猜:

printf("I guess the number is %d.Is it right(R, L or S)? ",rand()%100+1);

效果显著:

为系统坚持不懈的精神点赞!

2-2. 代码 v2.0——我会缩小范围!

显然,我们可以每一次缩小猜测范围。

char c='\0';
int tms=0,l=1,r=100;
while(c!='R')
{
    int t=rand()%(r-l+1)+l;
    printf("I guess the number is %d. Is it right(R, L or S)? ",t);
    scanf("%c%*c",&c);
    tms++;
    if(c=='R') break;
    if(c=='L') r=t;
    if(c=='S') l=t;
}

效率提升了:

系统:我是最快的!

2-3. 代码 v3.0——我会清白!

Never gonna tell a lie and hurt you~

前面的程序判定不了我们在说谎,因此我们可以就 v2.0 添加一些东西(当l≥r 时必定不合法)。

char c='\0';
int tms=0,l=1,r=100;
while(c!='R')
{
	int t=rand()%(r-l+1)+l;
	printf("I guess the number is %d. Is it right(R, L or S)? ",t);
	scanf("%c%*c",&c);
	tms++;
	if(c=='R') break;
	if(c=='L') r=t;
	if(c=='S') l=t;
	if(l>=r)
	{
		puts("You told a lie!");
		return 0;
	}
}

聪明多了:

2-4. 代码 v4.0——我会二分!

没错,就是众望所归的二分。

改动这个即可:

int t=l+r>>1;

rand():要我有何用?

如果还是猜50,效果:

计算机:惊不惊喜,意不意外!

But——《1 times》!

稍微改改即可,这里作者就不改了懒得改。

最终代码:

#include<bits/stdc++.h>
using namespace std;

int main()
{
	puts("Please think a number from 1 to 100. And then I'll guess it.");
	puts("If I guess right, you should say \"R\"(Right).");
	puts("If my guess is too large, you should say \"L\"(Large).");
	puts("If my guess is too small, you should say \"S\"(Small).");
	puts("DON'T TELL A LIE!\n");
	char c='\0';
	int tms=0,l=1,r=100;
	while(c!='R')
	{
		int t=l+r>>1;
		printf("I guess the number is %d. Is it right(R, L or S)? ",t);
		scanf("%c%*c",&c);
		tms++;
		if(c=='R') break;
		if(c=='L') r=t;
		if(c=='S') l=t;
		if(l>=r)
		{
			puts("You told a lie!");
			return 0;
		}
	}
	printf("I guess it %d times!",tms);
 	return 0;
}

到此这篇关于C++小游戏教程之猜数游戏的实现的文章就介绍到这了,更多相关C++猜数游戏内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯