谜题(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);
}
相关推荐
古城小栈1 小时前
Rust Tauri:构建轻量高性能跨平台桌面应用
开发语言·后端·rust
城市的稻草人VS1 小时前
rust【日志库】
前端·rust
Rust研习社3 小时前
Nightly 前瞻:cargo-script 让 Rust 也能写脚本
后端·rust·编程语言
CairBin4 小时前
TiphiaPress——Rust+React构建的个人博客框架
react.js·rust·tiphiapress
Rust研习社20 小时前
从碎片化到标准化:cargo-bp 如何重构 Rust 开发逻辑
后端·rust·编程语言
ZTStory20 小时前
mise 一款可以在项目中独立管理语言、环境变量和任务的工具
前端·rust·命令行
咸甜适中21 小时前
rust语言学习笔记Trait(十一)Deref、DerefMut(解引用)
笔记·学习·rust
特立独行的猫a1 天前
AtomMQTT--使用Rust语音实现的轻量级高性能MQtt服务器
服务器·开发语言·mqtt·rust·broker
恋喵大鲤鱼1 天前
Rust 结构体分类
rust·struct