谜题(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);
}
相关推荐
无名之逆14 小时前
在Rust生态中探索高性能HTTP服务器:Hyperlane初体验
运维·服务器·开发语言·后端·http·rust·自动化
Baihai_IDP18 小时前
基于 DeepSeek GRPO 的 1.5B Rust 代码生成模型训练实战
rust·llm·deepseek
一只小松许️20 小时前
Rust切片、结构体、枚举
开发语言·rust
Source.Liu1 天前
【学Rust写CAD】31 muldiv255函数(muldiv255.rs)
rust
m0_521118232 天前
Rust学习日记:编写一个Python扩展
python·rust
疏狂难除2 天前
【Tauri2】013——前端Window Event与创建Window
前端·javascript·rust·react·tauri2
Source.Liu2 天前
【学Rust写CAD】30 Alpha256结构体补充方法(alpha256.rs)
rust·cad
Source.Liu2 天前
【学Rust写CAD】25 变量类(variable.rs)
后端·rust
我是前端小学生2 天前
写给rust开发者:一文了解cargo-deny项目
rust
我是前端小学生2 天前
写给rust开发者:一文了解cargo-generate工具
rust