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)中,然后执行:

bash 复制代码
$ rustc advanced_guess_number.rs
$ ./advanced_guess_number

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

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

相关推荐
ytttr8735 小时前
隐马尔可夫模型(HMM)MATLAB实现范例
开发语言·算法·matlab
点云SLAM6 小时前
凸优化(Convex Optimization)理论(1)
人工智能·算法·slam·数学原理·凸优化·数值优化理论·机器人应用
jz_ddk6 小时前
[学习] 卫星导航的码相位与载波相位计算
学习·算法·gps·gnss·北斗
放荡不羁的野指针6 小时前
leetcode150题-动态规划
算法·动态规划
sin_hielo6 小时前
leetcode 1161(BFS)
数据结构·算法·leetcode
一起努力啊~6 小时前
算法刷题-二分查找
java·数据结构·算法
水月wwww7 小时前
【算法设计】动态规划
算法·动态规划
码农水水8 小时前
小红书Java面试被问:Online DDL的INSTANT、INPLACE、COPY算法差异
算法
iAkuya8 小时前
(leetcode)力扣100 34合并K个升序链表(排序,分治合并,优先队列)
算法·leetcode·链表
我是小狼君8 小时前
【查找篇章之三:斐波那契查找】斐波那契查找:用黄金分割去“切”数组
数据结构·算法