猜数字游戏

简介: 猜数字游戏

一:随机数的生成

1:rand函数

函数原型:int rand (void);

rand函数会返回一个伪随机数,范围是0-32767,使用时需要包含头文件stdlib.h

调试rand函数,这里调试5次,产生5个随机数:

调试两次后发现结果一致,其实rand函数生成的随机数都是伪随机的,并不是真正的随机数,而是通过某种算法生成的随机数。真正的随机数是无法预测下一个数的大少的。而rand函数是对一个叫“种子”的基准 值进行运算生成的随机数。之所以前面每次运行程序产生的随机数序列都是一样的,是因为rand函数生成随机数的默认种子是1。如果要生成不同的随机数,就是让种子发生变化。


2:srand函数

srand 函数可以改变种子的大小。

srand的原型:void srand(unsigned int seed);

程序在调用rand函数前需先调用srand函数,通过srand函数的参数seed来设置rand函数生成随机数时的种子,只要种子发生变化,随机数就会发生变化。也就是说,给srand的种子是随机的,rand就能生成随机数;什么时候srand的种子是随机的呢?


3:time

在程序中我们一般使用程序运行的时间作为种子的,因为时间一直在发生变化。

time函数可以获得时间,

time函数的原型:time-t time(time *t timer);

time函数会返回1970年1月1日0时0分0秒到程序运行时间之间的差值,单位;秒。返回的类型是time-t 类型,而srand函数是unsigned int类型,因此需要强制转换,如:srand(unsigned int)time。time函数的参数timer如果是NULL,就只是返回这个时间的差值,也叫:时间戳,写成

time(NULL);

time函数使用时需使用头文件time.h

上面的代码改写成:



两次运行的结果就不一样了。

srand函数一次函数中调用一次,不能多次调用。

1.4:设置随机数的范围


二:猜数字游戏实现

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

void game()

{

int r = rand() % 100 + 1;

int guess = 0;

while (1)

{

printf(“请猜数字”);

scanf(“%d”, &guess);

if (guess < r)

printf(“猜小了\n”);

else

{

    if (guess > r)
      printf("猜大了\n");
    else
    {
      printf("猜对了\n");
      break;
    }
  }
}

}

void menu()

{

printf(“xxxxxxxxxxxxxxxxxx\n”);

printf(“xxxx1.playxxxxxxxx\n”);

printf(“xxxx0.exitxxxxxxxx\n”);

printf(“xxxxxxxxxxxxxxxxxx\n”);

}

int main()

{

int input = 0;

srand((unsigned int)time(NULL));

do {

menu();

printf(“请选择\n”);

scanf(“%d”, &input);

switch (input)

{

case 1:

game();

break;

case 0:

printf(“游戏结束\n”);

break;

dafault:

printf(“选择错误,重新选择\n”);

break;

}

} while (input);

return 0;

}

加上对猜数的限制;如果5次猜不出来;

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

void game()

{

int r = rand() % 100 + 1;

int guess = 0;

int count = 5;

while (count)

{

printf(“你还有%d次机会”,count);

count–;

scanf(“%d”, &guess);

if (guess < r)

printf(“猜小了\n”);

else

{

    if (guess > r)
      printf("猜大了\n");
    else
    {
      printf("猜对了\n");
      break;
    }
  }
  if (count == 0)
    printf("你失败了,正确结果是%d\n", r);
}

}

void menu()

{

printf(“xxxxxxxxxxxxxxxxxx\n”);

printf(“xxxx1.playxxxxxxxx\n”);

printf(“xxxx0.exitxxxxxxxx\n”);

printf(“xxxxxxxxxxxxxxxxxx\n”);

}

int main()

{

int input = 0;

srand((unsigned int)time(NULL));

do {

menu();

printf(“请选择\n”);

scanf(“%d”, &input);

switch (input)

{

case 1:

game();

break;

case 0:

printf(“游戏结束\n”);

break;

dafault:

printf(“选择错误,重新选择\n”);

break;

}

} while (input);

return 0;

}


目录
相关文章
|
监控 数据挖掘 数据安全/隐私保护
ERP系统中的报价与报价管理模块解析
【7月更文挑战第25天】 ERP系统中的报价与报价管理模块解析
883 3
|
NoSQL 关系型数据库 MySQL
主备切换大揭秘:保证系统永不停机的秘密
本文由小米分享,介绍了分布式系统中的主备切换机制,旨在确保高可用性和可靠性。内容涵盖热备和冷备的概念,以及MySQL和Redis的主从复制原理和配置方法。通过主从复制,当主服务器故障时,备服务器能接管工作,维持服务连续性。文章还讨论了主备切换的挑战,如数据一致性与切换延迟,并提出了相应的解决方案。最后,作者鼓励读者就该主题提出疑问和建议。
1091 4
|
存储 缓存 NoSQL
28个案例问题分析---01---redis没有及时更新问题--Redis
28个案例问题分析---01---redis没有及时更新问题--Redis
522 0
|
8天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
7天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
348 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
19天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1333 8
|
7天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
336 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
|
6天前
|
监控 JavaScript Java
基于大模型技术的反欺诈知识问答系统
随着互联网与金融科技发展,网络欺诈频发,构建高效反欺诈平台成为迫切需求。本文基于Java、Vue.js、Spring Boot与MySQL技术,设计实现集欺诈识别、宣传教育、用户互动于一体的反欺诈系统,提升公众防范意识,助力企业合规与用户权益保护。