C语言实现猜数字游戏:代码详解与函数解析

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: C语言实现猜数字游戏:代码详解与函数解析

引言

在本篇博客中,我们将通过一个简单的C语言程序实例来介绍如何实现猜数字游戏。这个程序利用了随机数生成器和用户输入来创造一个互动体验,其中包含三个关键函数:initRandomSeedgenerateRandomNumbermain 函数。下面是对每个函数的详细解释以及整个程序的Markdown格式描述。

程序头文件导入

#include <stdio.h>
#include <time.h>
#include <stdlib.h>

这三个头文件分别用于标准输入输出操作(stdio.h)、获取当前时间(time.h)以及随机数生成(stdlib.h)。


随机数种子初始化优化

static _Bool isSrandIntialized = 0;

void initRandomSeed() {
    if (!isSrandIntialized) {
        srand((unsigned int) time(0));
        isSrandIntialized = 1;
    }
}

为了确保在整个程序生命周期内只初始化一次随机数种子,定义了一个静态布尔变量 isSrandIntializedinitRandomSeed 函数负责检查该变量状态,若尚未初始化,则调用 srand(time(0)) 来根据当前时间生成一个种子值,并将 isSrandIntialized 设置为 true,以防止重复初始化。

随机数生成函数

int generateRandomNumber(int min, int max) {
    initRandomSeed();
    return rand() % (max - min + 1) + min;
}

generateRandomNumber 函数接受两个整数参数,表示生成随机数的范围。它首先调用 initRandomSeed() 确保随机数种子已正确设置,然后使用 rand() 函数生成一个随机数,并通过取模运算保证生成的随机数位于指定区间 [min, max] 内。


主函数 main()

int main() {
    const int RANGE_MIN = 1;
    const int RANGE_MAX = 500;
    int computerNumber = generateRandomNumber(RANGE_MIN, RANGE_MAX);
    int userGuess;

    while (1) {
        printf("请输入一个%d-%d的数字:\n", RANGE_MIN, RANGE_MAX);
        scanf("%d", &userGuess);

        if (userGuess > computerNumber) {
            printf("猜大了\n");
        } else if (userGuess < computerNumber) {
            printf("猜小了\n");
        } else {
            printf("恭喜你,猜对了!\n");
            break;
        }
    }

    return 0;
}

在主函数 main() 中:

  • 定义常量 RANGE_MINRANGE_MAX 表示猜测数字的范围。
  • 使用 generateRandomNumber() 函数生成计算机选择的随机数 computerNumber
  • 启动无限循环,提示用户输入猜测的数字。
  • 判断用户输入的 userGuess 是否等于 computerNumber,并给出相应的提示信息。
  • 当用户猜中数字时,输出祝贺信息并使用 break 跳出循环。

完整代码

#include <stdio.h>
#include <time.h>
#include <stdlib.h>

// 优化 srand 初始化,确保在整个程序生命周期内仅初始化一次随机数种子
static _Bool isSrandIntialized = 0;

void initRandomSeed() {
    if (!isSrandIntialized) {
        srand((unsigned int) time(0));
        isSrandIntialized = 1;
    }
}

int generateRandomNumber(int min, int max) {
    initRandomSeed();
    return rand() % (max - min + 1) + min;
}

int main() {
    const int RANGE_MIN = 1;
    const int RANGE_MAX = 500;
    int computerNumber = generateRandomNumber(RANGE_MIN, RANGE_MAX);
    int userGuess;

    while (1) {
        printf("请输入一个%d-%d的数字:\n", RANGE_MIN, RANGE_MAX);
        scanf("%d", &userGuess);

        if (userGuess > computerNumber) {
            printf("猜大了\n");
        } else if (userGuess < computerNumber) {
            printf("猜小了\n");
        } else {
            printf("恭喜你,猜对了!\n");
            break;
        }
    }

    return 0;
}


总结:以上C语言程序实现了经典的猜数字游戏,通过合理地组织函数,使得代码逻辑清晰,同时保证了随机数生成的一致性和有效性。

相关文章
|
22天前
|
自然语言处理 搜索推荐 数据安全/隐私保护
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
鸿蒙登录页面设计展示了 HarmonyOS 5.0(Next)的未来美学理念,结合科技与艺术,为用户带来视觉盛宴。该页面使用 ArkTS 开发,支持个性化定制和无缝智能设备连接。代码解析涵盖了声明式 UI、状态管理、事件处理及路由导航等关键概念,帮助开发者快速上手 HarmonyOS 应用开发。通过这段代码,开发者可以了解如何构建交互式界面并实现跨设备协同工作,推动智能生态的发展。
136 10
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
|
1月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
156 14
|
1月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
55 8
|
1月前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
581 6
|
1月前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
50 5
|
1月前
|
C语言 开发者
【C语言】断言函数 -《深入解析C语言调试利器 !》
断言(assert)是一种调试工具,用于在程序运行时检查某些条件是否成立。如果条件不成立,断言会触发错误,并通常会终止程序的执行。断言有助于在开发和测试阶段捕捉逻辑错误。
48 5
|
1月前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
33 1
|
1月前
|
安全 搜索推荐 Unix
【C语言】《回调函数》详细解析
回调函数是指一个通过函数指针调用的函数。它允许将一个函数作为参数传递给另一个函数,并在特定事件发生时执行。这种技术使得编程更加灵活,可以动态决定在何时调用哪个函数。
56 1
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
103 2
|
20天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析

推荐镜像

更多