啊哈c语言——5.9逻辑挑战11(猜数游戏)

        计算机会随机地给出0~99之间的一个整数,你能否猜出这个数呢?每猜一次,计算机都会告诉你猜的数是大了还是小了,直到你猜出这个数为止。

        首先我们需要解决的第一个问题就是如何让计算机随机地产生一个整数,这个很简单:

#include <stdio.h>
#include <stdlib.h>
int main()
{
    int a;
    a = rand();
    printf("%d", a);
    system("pause");
    return 0;
}

        运行一下,计算机是不是随机打印了一个数?但是多运行几次你就会发现,每次打印的数都是一样的,并没有体现随机性。上面的代码中起到产生随机数作用的语句就是rand( ),但是只有rand( )是不够的,我们在rand( )前面加上srand((unsigned)time(NULL))就可以了,试一试吧,完整的代码如下。注意,这里用到了time( )函 数,因此要加上#include 才行。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
    int a;
    srand((unsigned)time(NULL));
    a = rand();
    printf("%d", a);
    system("pause");
    return 0;
}

        srand( )是用来初始化随机种子数的,这里我们通过当前时间来获得这个随机种子。time的值每时每刻都不同,所以种子不同,产生的随机数也不同。然后调用rand( ),它会根据提供给srand( )的种子值返回一个随机数(在啊哈C中为0~32767)。

        那么如何生成0~99的整数呢?很简单,只要求随机产生的数除以 100的余数就可以了:

        接下来的问题,就是你每输入一个数,就让计算机去判断是大了还是小了,直到猜对为止。

        输入数据我们可以用scanf语句,判断大小我们可以用if语句。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
    int a, b;
    srand((unsigned)time(NULL));
    a = rand()%100;
    scanf("%d", &b);
    if(b>a)
    printf("大了,请继续\n");
    if(b<a)
    printf("小了,请继续\n");
    if(b==a)
    {
        printf("恭喜你答对了\n");
    }
    system("pause");
    return 0;
}

        运行上面的代码你会发现,我们只猜了一次就不能猜了,在这里我 们用while循环来解决这个问题。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
    int a, b;
    srand((unsigned)time(NULL));
    a = rand()%100;
    while(1)
    {
        scanf("%d", &b);
        if(b>a)
        printf("大了,请继续\n");
        if(b<a)
        printf("小了,请继续\n");
        if(b==a)
        {
            printf("恭喜你答对了\n");
            break;
        }
    }
    system("pause");
    return 0;
}

在上面的代码中,我们使用while(1)让程序进入无限循环中,然后当你猜对时,也就是a==b时,用break;来及时退出循环。

        我们可以让这个程序变得更有趣一点——限定猜数的次数。

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
    int a, b, sum;
    sum=6;
    srand((unsigned)time(NULL));
    a = rand()%100;
    while(1)
    {
        sum--;
        scanf("%d", &b);
        if(b>a)
        printf("大了,还剩下%d次机会,请继续\n", sum);
        if(b<a)
        printf("小了,还剩下%d次机会,请继续\n", sum);
        if(b==a)
        {
            printf("恭喜你,答对了!\n");
            break;
        }
        if(sum==0)
        {
            printf("已经没有机会了,请重新开始吧!\n");
            break;
        }
    }
    system("pause");
    return 0;
}

        在上面的代码中,我们用sum来进行计数。初始的时候sum=6,表示有6次猜的机会,然后每猜一次就执行sum--,直到sum为0,全部机会 用完,程序结束。

更进一步,动手试一试

        想一想,如何生成一个1~20 000000的随机数?

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

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

相关文章

Oracle11.2.0.4从RMAN备份中快速恢复单个表的方法

文章目录 前言一、查询所要恢复的表所涉及的表空间二、创建用于恢复的数据库三、恢复步骤1.恢复控制文件2.修改redo日志名称3.表空间恢复4.表空间recover5.查询数据 前言 由于用户误操作导致某表中的数据错乱&#xff0c;导致业务不能正常使用&#xff0c;现需要将该表恢复到一…

结队编程 - 华为OD统一考试

OD统一考试 题解: Java / Python / C++ 题目描述 某部门计划通过结队编程来进行项目开发,已知该部门有 N 名员工,每个员工有独一无二的职级,每三个员工形成一个小组进行结队编程,结队分组规则如下: 从部门中选出序号分别为 i、j、k 的3名员工,他们的职级分别为 level[…

APP加固技术及其应用

文章目录 引言 APP加固的概念 APP加固的方案 APP加固在实际开发中的应用 总结 引言 在移动应用开发过程中&#xff0c;APP加固技术起到了非常重要的作用。APP加固是将apk文件进行混淆加密&#xff0c;以防止别人反编译获取我们的源码和资源文件。目前市场上主流的APP加固…

创新性文生视频模型,南洋理工开源FreeInit

文本领域的ChatGPT&#xff0c;画图领域的Midjourney都展现出了大模型强大的一面&#xff0c;虽然视频领域有Gen-2这样的领导者&#xff0c;但现有的视频扩散模型在生成的效果中仍然存在时间一致性不足和不自然的动态效果。 南洋理工大学S实验室的研究人员发现&#xff0c;扩散…

ElasticSearch 复合查询 Boolean Query

官网文档网址&#xff1a;Boolean query | Elasticsearch Guide [7.17] | Elastic 目录 复合查询 Boolean Query 利用bool查询实现功能 总结 复合查询 Boolean Query 布尔查询是一个或多个查询子句的组合。子查询的组合方式有&#xff1a; must:必须匹配每个子查询&#xf…

去年最火的 JS 开源项目「GitHub 热点速览」

1. 开源新闻 1.1 2023 年最火的 JS 开源项目 这份「2023 JavaScript Rising Stars」榜单&#xff0c;关注的是 2023 年 GitHub 上 Star 增长速度最快的 JavaScript 开源项目。该榜单显示&#xff0c;过去一年最热门的 JavaScript 项目是 &#x1f3c6;shadcn/ui&#xff0c; 这…

vue3中标签form插件

想写一个系统&#xff0c;对八字进行标注&#xff0c;比如格局&#xff0c;有些八字就有很多格局&#xff0c;于是就想着使用el-tag但是&#xff0c;form表单中如何处理呢&#xff1f; 这个时候&#xff0c;就需要自己写一个,modelValue是表单的默认属性 <template><…

LeetCode刷题---两数之和

解题思路&#xff1a; 该题使用哈希表的思想解决该问题 首先定义一个Map&#xff0c;key为数组中的每个元素&#xff0c;value为每个元素的索引下标。接着遍历原数组&#xff0c;对每一个元素进行判断&#xff0c;如果哈希表中包含target-nums[i]&#xff0c;则将其value和当前…

GEC6818传感器模块(烟雾+GY39+RFID)——使用文字取模的方式实现数据显示

GEC6818传感器模块(烟雾GY39RFID)——使用文字取模的方式实现数据显示 完整的工程大家可以在我的gitee上进行下载 下载地址&#xff1a;GEC6818智能语音家居系统 文章目录 GEC6818传感器模块(烟雾GY39RFID)——使用文字取模的方式实现数据显示一、 文字取模实现数据显示1. disp…

基于YOLOv5全系列参数模型【n/s/m/l/x】开发构建道路交通场景下CCTSDB2021交通标识检测识别系统

交通标志检测是交通标志识别系统中的一项重要任务。与其他国家的交通标志相比&#xff0c;中国的交通标志有其独特的特点。卷积神经网络&#xff08;CNN&#xff09;在计算机视觉任务中取得了突破性进展&#xff0c;在交通标志分类方面取得了巨大的成功。CCTSDB 数据集是由长沙…

LXD容器中通过Qemu安装Win7虚拟机(呕心制作-诸多细节)

前言 为了抵御网络攻击&#xff0c;实验复现某些计算机漏洞&#xff0c;需要安装Win7操作系统。 真是呕心制作&#xff0c;反复尝试好多次&#xff0c;搜索很多相关资料&#xff0c;终于总结出这篇文章&#xff0c;其目的是通过虚拟化技术&#xff0c;完成Win7的安装配置。其中…

imgaug库指南(九):从入门到精通的【图像增强】之旅

引言 在深度学习和计算机视觉的世界里&#xff0c;数据是模型训练的基石&#xff0c;其质量与数量直接影响着模型的性能。然而&#xff0c;获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此&#xff0c;数据增强技术应运而生&#xff0c;成为了解决这一问题的…

计算机网络(超级详细笔记)

使用教材计算机网络&#xff08;第8版&#xff09;&#xff08;谢希仁&#xff09; 第一章&#xff1a;概述 第二章&#xff1a;物理层 第三章&#xff1a;数据链路层 第四章&#xff1a;网络层 第五章&#xff1a;运输层 第六章&#xff1a;应用层 目…

王中阳Go赠书活动第一期:《TVM编译器原理与实践》

文章目录 前言TVM编译器的实现过程关于《TVM编译器原理与实践》编辑推荐内容简介作者简介图书目录书中前言/序言《TVM编译器原理与实践》全书速览入手《TVM编译器原理与实践》传送门&#xff1a;结束语参加抽奖 前言 随着人工智能的发展&#xff0c;计算机视觉、自然语言处理和…

RapidSSL和Geotrust的通配符证书区别

RapidSSL颁发的数字证书产品方便快捷&#xff0c;只有一款DV基础型通配符SSL证书&#xff0c;只需要验证域名所有权就可以签发证书。Geotrust旗下的通配符SSL证书产品不止一款&#xff0c;既有DV基础型通配符SSL证书&#xff0c;也有OV企业型通配符SSL证书。今天就随SSL盾小编了…

【每日论文阅读】Do Perceptually Aligned Gradients Imply Robustness?

近似人眼梯度 https://icml.cc/virtual/2023/oral/25482 对抗性鲁棒分类器具有非鲁棒模型所没有的特征——感知对齐梯度&#xff08;PAG&#xff09;。它们相对于输入的梯度与人类的感知非常一致。一些研究已将 PAG 确定为稳健训练的副产品&#xff0c;但没有一篇研究将其视为…

性能分析与调优: Linux 实现 CPU剖析与火焰图

目录 一、实验 1.环境 2.CPU 剖析 3.CPU火焰图 一、实验 1.环境 &#xff08;1&#xff09;主机 表1-1 主机 主机架构组件IP备注prometheus 监测 系统 prometheus、node_exporter 192.168.204.18grafana监测GUIgrafana192.168.204.19agent 监测 主机 node_exporter192…

产教融合 | 湖南科技大学近千名学子走进云畅科技,深度研学低代码技术与应用

近日&#xff0c;湖南科技大学计算机学院和潇湘学院的2022级共918名同学齐聚湖南云畅网络科技有限公司&#xff08;简称“云畅科技”&#xff09;&#xff0c;展开了一场深入了解低代码行业前沿技术的研学之旅。此次活动旨在拓展学生视野&#xff0c;提升对数字化转型的认知&am…

Jmeter扩展函数?年薪50W+的测试大佬教你怎么玩

我的 jmeter 里面&#xff0c;怎么没有 MD5 函数&#xff0c;base64 函数也没有&#xff0c;我是不是用了假的 jmeter&#xff1f; 哈哈哈&#xff0c;不是的。jmeter 的函数&#xff0c;有自带函数和扩展函数两大块&#xff0c;自带函数&#xff0c;就是 jmeter 官方自带的&a…

React.Children.map 和 js 的 map 有什么区别?

JavaScript 中的 map 不会对为 null 或者 undefined 的数据进行处理&#xff0c;而 React.Children.map 中的 map 可以处理 React.Children 为 null 或者 undefined 的情况。 React 空节点&#xff1a;可以由null、undefined、false、true创建 import React from reactexport …