谜题(Puzzle, ACM/ICPC World Finals 1993, UVa227)rust解法

有一个5*5的网格,其中恰好有一个格子是空的,其他格子各有一个字母。一共有4种指令:A, B, L, R,分别表示把空格上、下、左、右的相邻字母移到空格中。输入初始网格和指令序列(以数字0结束),输出指令执行完毕后的网格。如果有非法指令,应输出"This puzzle has no final configuration.",例如,图3-5中执行ARRBBL0后,效果如图3-6所示。

解法

复制代码
use std::io;

fn main() {
    let mut grid: Vec<Vec<char>> = vec![];
    for _i in 0..5 {
        let mut buf = String::new();
        io::stdin().read_line(&mut buf).unwrap();
        let cs = buf.trim().chars().collect();
        grid.push(cs);
    }
    println!("{:#?}", grid);

    let mut buf = String::new();
    io::stdin().read_line(&mut buf).unwrap();
    let cmds = buf.trim();
    println!("{}", cmds);

    let mut kong = (0, 0);
    for i in 0..5 {
        for j in 0..5 {
            if grid[i][j] == ' ' {
                kong = (i, j);
                break;
            }
        }
    }
    for i in cmds.chars() {
        match i {
            'a' => {
                if kong.0 < 1 {
                    panic!("This puzzle has no final configuration");
                }
                let c = grid[kong.0 - 1][kong.1];
                grid[kong.0][kong.1] = c;
                grid[kong.0 - 1][kong.1] = ' ';
                kong = (kong.0 - 1, kong.1);
            }
            'b' => {
                if kong.0 >= 4 {
                    panic!("This puzzle has no final configuration");
                }
                let c = grid[kong.0 + 1][kong.1];
                grid[kong.0][kong.1] = c;
                grid[kong.0 + 1][kong.1] = ' ';
                kong = (kong.0 + 1, kong.1);
            }
            'l' => {
                if kong.1 < 1 {
                    panic!("This puzzle has no final configuration");
                }
                let c = grid[kong.0][kong.1 - 1];
                grid[kong.0][kong.1] = c;
                grid[kong.0][kong.1 - 1] = ' ';
                kong = (kong.0, kong.1 - 1);
            }
            'r' => {
                if kong.1 >= 4 {
                    panic!("This puzzle has no final configuration");
                }
                let c = grid[kong.0][kong.1 + 1];
                grid[kong.0][kong.1] = c;
                grid[kong.0][kong.1 + 1] = ' ';
                kong = (kong.0, kong.1 + 1);
            }
            '0' => {
                break;
            }
            _ => {
                panic!("This puzzle has no final configuration");
            }
        }
    }
    println!("{:#?}", grid);
}
相关推荐
i_am_a_div_日积月累_1 小时前
jenkins打包报错
运维·rust·jenkins·jenkins打包报错
初学者,亦行者11 小时前
Rayon并行迭代器:原理、实践与性能优化
java·开发语言·spring·rust
RustCoder13 小时前
Rust 1.91 发布:ARM Windows 正式跻身顶级支持,悬空指针警告上线
后端·性能优化·rust
Kapaseker14 小时前
深入 Rust 迭代器(中)
rust
muyouking1115 小时前
Rust + WASM + Svelte 深度实战:内存管理、性能权衡与图像处理进阶
开发语言·rust·wasm
2301_7951672015 小时前
玩转Rust高级应用 如何进行面向对象设计模式的实现,实现状态模式
设计模式·rust·状态模式
2301_7965125215 小时前
Rust编程学习 - 如何快速构建一个单线程 web server
前端·学习·rust
想不明白的过度思考者1 天前
Rust——异步递归深度指南:从问题到解决方案
开发语言·后端·rust
逻极1 天前
Rust数据类型(上):标量类型全解析
开发语言·后端·rust
Zhangzy@1 天前
Rust 编译优化选项
android·开发语言·rust