Rust猜数字游戏

这篇具有很好参考价值的文章主要介绍了Rust猜数字游戏。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Rust进阶:猜数字游戏

Rust是一门现代的系统级编程语言,注重内存安全、并发性能以及表达力。在这篇博客中,我们将深入介绍一个更加复杂的猜数字游戏代码,展示Rust语言的一些高级特性。

代码示例

以下是一个升级版的Rust猜数字游戏代码:

use std::io;
use std::cmp::Ordering;
use rand::Rng;

fn main() {
    println!("猜数字!");
    // 生成一个1到100之间的随机数
    let secret_number = rand::thread_rng().gen_range(1..101);
    //println!("神秘数字:{}", secret_number);

    // 游戏主循环
    loop {
        println!("猜测一个数");
        let mut guess = String::new();

        io::stdin().read_line(&mut guess).expect("无法读取行");

        // 使用类型遮蔽(Shadowing)实现类型转换
        let guess: u32 = match guess.trim().parse() {
            Ok(num) => num,
            Err(_) => continue,
        };

        // 使用模式匹配比较猜测的数字和神秘数字
        match guess.cmp(&secret_number) {
            Ordering::Less => println!("太小了!"),
            Ordering::Greater => println!("太大了!"),
            Ordering::Equal => {
                println!("恭喜你,猜对了!");
                break;
            }
        }
    }
}

代码解析

这个升级版的猜数字游戏引入了一些新的概念和库:

  1. use std::cmp::Ordering;:导入Ordering枚举,用于比较两个值的大小关系。

  2. use rand::Rng;:导入rand库中的Rng trait,用于生成随机数。

  3. let secret_number = rand::thread_rng().gen_range(1..101);:使用rand库生成一个1到100之间的随机数,作为神秘数字。

  4. match guess.cmp(&secret_number) { ... }:使用match表达式和cmp方法比较猜测的数字和神秘数字,根据大小关系输出相应提示。

  5. loop { ... }:引入一个无限循环,直到玩家猜对为止。

  6. 使用类型遮蔽(Shadowing):在原有变量guess上重新声明,进行类型转换。这允许我们保持可变性并改变变量的类型。

运行代码

要运行这个升级版的猜数字游戏,同样保存到一个.rs文件(例如advanced_guess_number.rs)中,然后执行:

$ rustc advanced_guess_number.rs
$ ./advanced_guess_number

现在,您将体验到一个更加交互和有趣的猜数字游戏,体现了Rust语言的强大和灵活性。

总的来说,这个博客通过猜数字游戏代码的逐步升级,展示了Rust语言的一些高级特性,如模式匹配、trait使用和库的集成。希望这能够帮助您更深入地理解和学习Rust编程。文章来源地址https://www.toymoban.com/news/detail-827252.html

到了这里,关于Rust猜数字游戏的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 算法leetcode|45. 跳跃游戏 II(rust重拳出击)

    给定一个长度为 n 的 0 索引整数数组 nums 。初始位置为 nums[0] 。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说,如果你在 nums[i] 处,你可以跳转到任意 nums[i + j] 处: 0 = j = nums[i] i + j n 返回到达 nums[n - 1] 的 最小跳跃次数 。生成的测试用例可以到达 nums[n - 1] 。

    2023年04月15日
    浏览(51)
  • 猜数游戏-Rust版

    cargo new guessing_game 创建项目 输入任意内容,并打印出来 main.rs: 生成随机数 Cargo.toml rand包还依赖libc 比较大小 做多次猜测,直到猜对 本文由 mdnice 多平台发布

    2024年02月11日
    浏览(32)
  • 使用 Rust 开发一个微型游戏

    建立项目 实现 Game loop 不同的游戏模式 添加玩家 添加障碍和计分 汇总 为了让游戏流畅、顺滑的运行,需要使用 Game loop Game loop: 初始化窗口、图形和其它资源 每当屏幕刷新(通常是每秒 30、60或更多次),它都会运行 每次通过循环,它都会调用游戏的 tick() 函数 开始 - 配

    2024年02月06日
    浏览(36)
  • Rust每日一练(Leetday0022) 最小路径和、有效数字、加一

    目录 64. 最小路径和 Minimum Path Sum  🌟🌟 65. 有效数字 Valid Number  🌟🌟🌟 66. 加一 Plus One  🌟 🌟 每日一练刷题专栏 🌟 Rust每日一练 专栏 Golang每日一练 专栏 Python每日一练 专栏 C/C++每日一练 专栏 Java每日一练 专栏 给定一个包含非负整数的  m  x  n  网格  grid  ,请找

    2024年02月08日
    浏览(39)
  • 一个简单的 rust 项目 使用 bevy 引擎 复刻 Flappy Bird 小游戏

    一个使用 bevy 引擎复刻的 Flappy Bird 经典小游戏。 通过该项目我们可以学到:bevy 的自定义组件,自定义插件,自定义资源,sprite 的旋转,sprite 的移动,sprite sheet 动画的定义使用,状态管理,等内容… 简单介绍一下包含的内容: 游戏状态管理 Menu、InGame、Paused、GameOver。 小

    2023年04月24日
    浏览(47)
  • Rust常用加密算法

    哈希运算(以Sha256为例) main.rs : Cargo.toml : 输出为: 6d65924d8e0580b9ac04d13da91c74c3ae28b08b4be4634ae06e647f42a88913 可以在线比对验证一下 验证数据完整性(使用HMAC) MAC(Message Authentication Code,消息认证码算法)是含有密钥散列函数算法,兼容了MD和SHA算法的特性,并在此基础上加上了密钥。

    2024年02月11日
    浏览(31)
  • 算法leetcode|66. 加一(rust重拳出击)

    给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。 最高位数字存放在数组的首位, 数组中每个元素只存储 单个 数字。 你可以假设除了整数 0 之外,这个整数不会以零开头。 1 = digits.length = 100 0 = digits[i] = 9 面对这道算法题目,二当家的再次陷入了

    2024年02月14日
    浏览(38)
  • 算法leetcode|71. 简化路径(rust重拳出击)

    给你一个字符串 path ,表示指向某一文件或目录的 Unix 风格 绝对路径 (以 \\\'/\\\' 开头),请你将其转化为更加简洁的规范路径。 在 Unix 风格的文件系统中,一个点( . )表示当前目录本身;此外,两个点 ( .. ) 表示将目录切换到上一级(指向父目录);两者都可以是复杂相

    2024年02月12日
    浏览(45)
  • 算法leetcode|72. 编辑距离(rust重拳出击)

    给你两个单词 word1 和 word2 , 请返回将 word1 转换成 word2 所使用的最少操作数 。 你可以对一个单词进行如下三种操作: 插入一个字符 删除一个字符 替换一个字符 0 = word1.length, word2.length = 500 word1 和 word2 由小写英文字母组成 面对这道算法题目,二当家的再次陷入了沉思。 编

    2024年02月12日
    浏览(43)
  • 算法leetcode|85. 最大矩形(rust重拳出击)

    给定一个仅包含 0 和 1 、大小为 rows x cols 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积。 rows == matrix.length cols == matrix[0].length 1 = row, cols = 200 matrix[i][j] 为 ‘0’ 或 ‘1’ 面对这道算法题目,二当家的再次陷入了沉思。 要不是刚做过 84. 柱状图中最大的矩形 这

    2024年02月08日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包