c语言修炼之猜数字游戏

前言

小伙伴们,今天来学习猜数字游戏叭!废话不多说,让我们一起开始学习叭!

思路:

一打开游戏就出现一个菜单然后可以让我们选择是进入游戏还是退出游戏!

#include<stdio.h>
void menu()
{
	printf("********************************\n");
	printf("****** 0.exit   1.play *********\n");
	printf("********************************\n");
}
int main()
{
	menu();

}

就像这样啦!就可以打印出菜单啦!此时我们要在创建一个变量input用来选择是进入游戏还是退出游戏,并且再提示一下玩家输入选择!

#include<stdio.h>
void menu()
{
	printf("********************************\n");
	printf("****** 0.exit   1.play *********\n");
	printf("********************************\n");
}
int main()
{
	int input = 0;
	menu();
	printf("请输入你的选择:>");
	scanf("%d", &input);
	
	return 0;

}

运行看看叭!

能够发现没有达到我们想要的效果哦!没有进入游戏也没有退出游戏的动作!这时我们应该用switch语句,酱酱们还记得switch语法形式吗?switch语句适用于多分支的情况,其语法形式如下:

switch (常量表达式)
{
case 常量项:
		语句项;
}

利用switch语句时,再来看看效果吧 

是达到了之前想要的效果,但是当我们觉得不过瘾想要再来一把时会发现游戏直接结束了,无法再开一把!这该怎么办呢?没错这里我们需要使用一个循环语句!循环语句有三种该选择哪一个呢?是while,for,还是do while呢?这里我们将选择do while语句还记得它与众不同的特点吗:先执行再判断!先玩一把结束之后再选择要不要继续!

#include<stdio.h>
void menu()
{
	printf("**********************\n");
	printf("**** 0.exit  .play ***\n");
	printf("**********************\n");
}
int main()
{
	int input = 0;
	do
	{
		menu();
		printf("请输入你选择的值:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			printf("进入游戏\n");
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("输入错误\n");
			break;
		}
	} while (input);
	return 0;
}

此时就能达到我们想要的效果啦!让给我们开始分装game函数叭就不再用printf了!game函数的话负责具体实现猜数字的内容!

第一步我们需要产生随机数,此处我们需要用到rand函数!不了解的小伙伴可以去cplusplus网站上去查看

左上角的function表示rand是一个函数,返回类型是int,参数为空,其范围为0到RAND_MAX,在使用rand函数时必须引用头文件stdlib.h画线的部分意思需要用deepl进行翻译

翻译的结果是使用rand之前要先调用srand函数,再来查一下srand函数叭 

 srand返回类型为空,其参数类型要为unsigned int,其主要作用是初始化随机数发生!其头文件为stdlib.h。接下来开始解决遇到的问题叭!我们要产生一个一到一百的数,该怎么得到呢?rand的值的范围是0到RAND_MAX,我们使得rand%100就能得到0到99的值再加上1就能得到1到100之间的数字啦,同时用一个变量接收这个值!一起来看看效果叭

#include<stdio.h>
#include<stdlib.h>
void menu()
{
	printf("**********************\n");
	printf("**** 0.exit  .play ***\n");
	printf("**********************\n");
}
void game()
{
	srand(1);
	int ret= rand() % 100 + 1;
	printf("%d\n", ret);
}
int main()
{
	int input = 0;
	do
	{
		menu();
		printf("请输入你选择的值:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("输入错误\n");
			break;
		}
	} while (input);
	return 0;
}

 貌似不对呀,为啥产生的数不是随机的·而是同一个呢?问题出在哪呢?rand没问题main函数没问题,那就只能是srand出问题了。上面用的是srand(1),那换成srand(2)试试?

 也是一样的欸,那是不是说明srand里需要一个会变化的参数!什么是一直变化的呢?没错就是时间!那么这里我们需要利用时间戳                                                                                                

 此时就要利用time函数,再上cplusplus查一查叭

 time函数返回类型是time_t,参数是指针类型,作用是获取当前时间,头文件是time.h!已经知道了这些我们再对代码进行修改叭

void game()
{
	srand((unsigned int)time(NULL));
	int ret= rand() % 100 + 1;
	printf("%d\n", ret);
}

 

 是产生值了,但是貌似不够随机!这又是因为什么呢?好叭,问题还是出现在srand函数上!在这里我们调用一次就行,不需要玩一次调用一次!直接放在main函数中即可,再来试试叭酱酱们

运行一下试试叭!

此时就能达到我们想要的结果啦!在进行下一步叭,输入我们猜的数字当猜的数字比产生的数大,大,打印猜大了;比产生的数小,提示猜小了,否则提示猜对了并退出。由于一次就猜对的可能性比较小,因此这里是一个循环!

void game()
{
	int ret= rand() % 100 + 1;
	int guess = 0;
	
	while (1)
	{
		printf("请输入你想猜的值:>");
		scanf("%d", &guess);
		if (guess > ret)
		{
			printf("猜大啦\n");
		}
		else if (guess < ret)
		{
			printf("猜小了\n");
		}
		else
		{
			printf("猜对了\n");
			break;
		}
	}
}

game函数的分装就完成啦!运行一下看看叭

 欧克啦,这就是猜数字游戏得过程啦,上完整代码!

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void menu()
{
	printf("**********************\n");
	printf("**** 0.exit  1.play **\n");
	printf("**********************\n");
}
void game()
{
	int ret= rand() % 100 + 1;
	int guess = 0;
	
	while (1)
	{
		printf("请输入你想猜的值:>");
		scanf("%d", &guess);
		if (guess > ret)
		{
			printf("猜大啦\n");
		}
		else if (guess < ret)
		{
			printf("猜小了\n");
		}
		else
		{
			printf("猜对了\n");
			break;
		}
	}
}
int main()
{
	int input = 0;
	srand((unsigned int)time(NULL));
	do
	{
		menu();
		printf("请输入你选择的值:>");
		scanf("%d", &input);
		switch (input)
		{
		case 1:
			game();
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("输入错误\n");
			break;
		}
	} while (input);
	return 0;
}

以上就是今天的学习啦 

 

 

 

 

 

 

 

 

 

 

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【MySQL】基本查询之表的增删改查

【MySQL】表的增删改查 一、插入操作----insert1.1 简单插入1.2 插入时是否更新----ON DUPLICATE KEY UPDATE1.3 插入时替换----REPLACE 二、查询----select2.1 简单查询与去重2.2 基本查询----where条件2.2.3 案列演示 2.4 排序----order by 三、修改操作----update四、删除--…

Lua学习笔记:浅谈table的实现

前言 本篇在讲什么 Lua中的table的实现 本篇适合什么 适合初学Lua的小白 本篇需要什么 对Lua语法有简单认知 依赖Sublime Text编辑器 本篇的特色 具有全流程的图文教学 重实践&#xff0c;轻理论&#xff0c;快速上手 提供全流程的源码内容 ★提高阅读体验★ &…

大数据Doris(五十三):MySQL Dump 导出

文章目录 MySQL dump 导出 一、Dump导出案例 二、注意事项 MySQL Dump 导出 mysqldump是一个常用的 MySQL 数据库备份工具&#xff0c;它可以将 MySQL 数据库中的数据导出为 SQL 格式的文件&#xff0c;从而实现对数据的备份、迁移和恢复等操作。Doris 在0.15 之后的版本已…

青岛大学_王卓老师【数据结构与算法】Week04_03_双向链表_学习笔记

本文是个人学习笔记&#xff0c;素材来自青岛大学王卓老师的教学视频。 一方面用于学习记录与分享&#xff0c;另一方面是想让更多的人看到这么好的《数据结构与算法》的学习视频。 如有侵权&#xff0c;请留言作删文处理。 课程视频链接&#xff1a; 数据结构与算法基础–…

Spring Boot 集成 Redisson分布式锁

Redisson 是一种基于 Redis 的 Java 驻留集群的分布式对象和服务库&#xff0c;可以为我们提供丰富的分布式锁和线程安全集合的实现。在 Spring Boot 应用程序中使用 Redisson 可以方便地实现分布式应用程序的某些方面&#xff0c;例如分布式锁、分布式集合、分布式事件发布和订…

Oracle数据库软件安装与卸载

Oracle数据库软件安装与卸载 实验目的及要求 学习Oracle12c数据库服务器软件和客户端软件的安 装与卸载,掌握客户端服务名的设置,建立客户端与服务器的网络连接,熟悉windows操作系统中Oracle相关服务的操作。理解数据库管理的基本架构。 &#xff08;1&#xff09;熟悉Oracle…

基于SpringBoot+SpringCloud+vue的智慧养老平台设计与实现

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

虚拟机上用docker + nginx跑前端并支持https和http

情况是这样&#xff0c;我在虚拟机上&#xff0c;使用docker跑前端&#xff0c;需要这个前端支持https&#xff0c;原http的话自动跳转到https。另外&#xff0c;前端部署使用了负载均衡&#xff0c;即使用了3个docker跑前端&#xff1a;1个入口&#xff0c;另外2个是前端&…

【macOS 系列】mac设置截屏或其他操作的默认保存位置

1、第一步、在用户/图片文件夹下&#xff0c;新建“截图”文件夹 2、第二步、打开终端&#xff0c;输入defaults write com.apple.screencapture location ~/Pictures/截图/后回车 3、第三步、操作完成后&#xff0c;再次输入killall SystemUIServer后回车 如果你在web前端开发…

clickhouse中时间戳转换--网上都没有,自己总结的

第一种&#xff1a; 库里时间戳为13位时&#xff1a; 类似这种13位的时间戳&#xff1a;1476141341051 怎么转换成正常的日期&#xff1a; 如果库里存的string类型&#xff0c;需要toUInt64(date_time) date_time的值为&#xff1a;1476141341051 然后利用toDateTime&…

远古 Windows 98 SE 和 putty 0.63 连接 SSH

远古 Windows 98 SE 和 putty 0.63 连接 SSH 不忘初心一、故障表现二、产生原因三、解决办法四、重启 SSHD 服务生交配置参考 作者&#xff1a;高玉涵 时间&#xff1a;2023.7.1 操作系统&#xff1a; Windows 98 第二版 4.10.2222 A Linux version 5.19.0-32-generic (build…

Redis实战——商户查询(二)

缓存穿透 缓存穿透 &#xff1a;客户端请求的数据在缓存中和数据库中都不存在&#xff0c;这样缓存永远不会生效&#xff0c;这样的请求都会访问到数据库&#xff0c;这样的大量请求同时过来访问这种不存在的数据&#xff0c;这些请求就都会访问到数据库&#xff0c;对数据库造…

基于smardaten无代码开发舆情分析系统

一、前言 在日常生活中&#xff0c;有各种各样的资讯、社交平台。这些平台充斥着大量信息&#xff0c;这些信息中隐含了许多有用数据&#xff0c;但是这些数据无法之间获取&#xff0c;且难以展示&#xff0c;于是就有了舆情分析系统。 舆情分析系统是一个综合的系统&#xf…

基于minsit数据集的图像分类任务|CNN简单应用项目

Github地址 Image-classification-task-based-on-minsit-datasethttps://github.com/Yufccode/CollegeWorks/tree/main/ImageProcessing/Image-classification-task-based-on-minsit-dataset README 摘要 本次实验报告用两种方式完成了基于minst数据集完成了图像的分类任务…

被吐槽 GitHub仓 库太大,直接 600M 瘦身到 6M,这下舒服了

前言 忙里偷闲学习了点技术写了点demo代码&#xff0c;打算提交到我那 2000Star 的Github仓库上&#xff0c;居然发现有5个Issues&#xff0c;最近的一条日期已经是2022/8/1了&#xff0c;以前我还真没留意过这些&#xff0c;我这人懒得很&#xff0c;本地代码提交成功基本就不…

Python dict keys方法:获取字典中键的序列【将keys转为list】

描述 dict.keys()方法是Python的字典方法&#xff0c;它将字典中的所有键组成一个可迭代序列并返回。 使用示例 >>> list({Chinasoft:China, Microsoft:USA}.keys()) [Chinasoft, Microsoft] >>> test_dict {Chinasoft:China, Microsoft:USA, Sony:Japan,…

【计算机视觉 | 目标检测】arxiv 计算机视觉关于目标检测的学术速递(7 月 4 日论文合集)

文章目录 一、检测相关(15篇)1.1 Artifacts Mapping: Multi-Modal Semantic Mapping for Object Detection and 3D Localization1.2 Shi-NeSS: Detecting Good and Stable Keypoints with a Neural Stability Score1.3 HODINet: High-Order Discrepant Interaction Network for…

机器学习一:线性回归

1 知识预警 1.1 线性代数 ( A T ) T A (A^\mathrm{T})^\mathrm{T}A (AT)TA$ ( A B ) T A T B T (AB)^\mathrm{T}A^\mathrm{T}B^\mathrm{T} (AB)TATBT ( λ A ) T λ A T (\lambda A)^\mathrm{T}\lambda A^\mathrm{T} (λA)TλAT ( A B ) T B T A T (AB)^\mathrm{T}B^…

【算法与数据结构】28、LeetCode实现strStr函数

文章目录 一、题目二、暴力穷解法三、KMP算法四、Sunday算法五、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、暴力穷解法 思路分析&#xff1a;首先判断字符串是否合法&#xff0c;然后利用for循环&#xff…

2023年全国节能宣传“节能低碳,你我同行”主题有奖竞答

2023年的7月10日至16日是第33个全国节能宣传周&#xff0c;主题是“节能降碳&#xff0c;你我同行”。 为践行低碳生活&#xff0c;切实做到节能降碳&#xff0c;各大企事业单位纷纷举办“节能低碳&#xff0c;你我同行”主题2023年全国节能宣传有奖竞答。 有奖知识竞答活动方…