首页 > 其他分享 >Rust求解八皇后问题

Rust求解八皇后问题

时间:2024-10-21 23:20:03浏览次数:3  
标签:求解 board 放置 皇后 queens col Rust row

在这里插入图片描述

八皇后问题是一个经典的回溯算法问题,目的是在 8x8 的棋盘上放置 8 个皇后,使得它们不能相互攻击。也就是说,任意两个皇后不能在同一行、同一列或同一对角线上。

这是一个使用 Rust 解决八皇后问题的完整代码,并附有详细的注解。Rust 和 Haskell 等函数式语言不同,在处理递归或高阶函数时,语法略有不同。我们可以使用回溯算法来解决这个问题。

Rust 解决八皇后问题的源代码:

fn main() {
    let n = 8;
    let mut board = vec![];  // 用于保存棋盘的状态,board[i] 代表第 i 列的皇后位置(即行号)
    solve_n_queens(n, &mut board);
}

fn solve_n_queens(n: usize, board: &mut Vec<usize>) {
    if board.len() == n {
        print_board(board, n);  // 如果所有皇后都放置完毕,打印当前解
    } else {
        for row in 0..n {
            if is_safe(board, row) {
                board.push(row);  // 将皇后放在当前列的 row 行
                solve_n_queens(n, board);  // 递归地放置下一列的皇后
                board.pop();  // 回溯,移除当前列的皇后,尝试下一个可能的行
            }
        }
    }
}

// 判断是否可以安全地在当前列的某一行放置皇后
fn is_safe(board: &Vec<usize>, row: usize) -> bool {
    let current_col = board.len();  // 当前要放置的列号
    
    for (col, &placed_row) in board.iter().enumerate() {
        // 检查:
        // 1. 同一行(不能在同一行放置皇后)
        // 2. 对角线(不能在对角线上放置皇后)
        if placed_row == row || (placed_row as isize - row as isize).abs() == (current_col as isize - col as isize) {
            return false;  // 如果同一行或对角线冲突,返回 false
        }
    }
    
    true  // 如果没有冲突,返回 true
}

// 打印棋盘的状态
fn print_board(board: &Vec<usize>, n: usize) {
    for &row in board.iter() {
        let mut line = vec!['.'; n];  // 初始化每一行,所有位置默认都是 "."
        line[row] = 'Q';  // 在当前行的正确位置放置皇后 "Q"
        println!("{}", line.iter().collect::<String>());  // 打印该行
    }
    println!();  // 每个解之间空一行
}

代码的详细解释:

  1. 主函数 main:

    fn main() {
        let n = 8;
        let mut board = vec![];  // 用于保存棋盘的状态,board[i] 代表第 i 列的皇后位置(即行号)
        solve_n_queens(n, &mut board);
    }
    
    • 这里的 n 是皇后数量(问题的大小),即 8 皇后问题。
    • board 是一个 Vec<usize>,用于保存每一列的皇后位置。board[i] 表示第 i 列的皇后所处的行号。我们一开始用空的棋盘开始。
    • 调用 solve_n_queens 函数,它负责递归地解决问题并找到所有解。
  2. 递归求解函数 solve_n_queens:

    fn solve_n_queens(n: usize, board: &mut Vec<usize>) {
        if board.len() == n {
            print_board(board, n);  // 如果所有皇后都放置完毕,打印当前解
        } else {
            for row in 0..n {
                if is_safe(board, row) {
                    board.push(row);  // 将皇后放在当前列的 row 行
                    solve_n_queens(n, board);  // 递归地放置下一列的皇后
                    board.pop();  // 回溯,移除当前列的皇后,尝试下一个可能的行
                }
            }
        }
    }
    
    • solve_n_queens 是递归求解八皇后问题的核心函数。
    • 它首先检查当前列是否已经放置了所有皇后,如果是,就调用 print_board 函数输出棋盘。
    • 如果还没放满皇后,程序会逐行尝试在当前列放置皇后,并通过 is_safe 检查当前行是否安全。如果安全,将该行号加入棋盘(board.push(row)),然后递归地解决下一列(调用 solve_n_queens)。
    • 在尝试所有可能行之后,通过 board.pop() 回溯,移除之前放置的皇后,继续尝试下一行。
  3. 安全检查函数 is_safe:

    fn is_safe(board: &Vec<usize>, row: usize) -> bool {
        let current_col = board.len();  // 当前要放置的列号
        
        for (col, &placed_row) in board.iter().enumerate() {
            // 检查:
            // 1. 同一行(不能在同一行放置皇后)
            // 2. 对角线(不能在对角线上放置皇后)
            if placed_row == row || (placed_row as isize - row as isize).abs() == (current_col as isize - col as isize) {
                return false;  // 如果同一行或对角线冲突,返回 false
            }
        }
        
        true  // 如果没有冲突,返回 true
    }
    
    • is_safe 函数检查在当前列的某一行放置皇后是否安全。
    • 它遍历 board 中已经放置的所有皇后,确保不会与当前尝试放置的皇后冲突。冲突的条件是:
      1. 在同一行(placed_row == row)。
      2. 在同一对角线(两个皇后的行差和列差的绝对值相等,即 (placed_row - row).abs() == (current_col - col))。
    • 如果有任何冲突,返回 false;否则,返回 true
  4. 打印棋盘函数 print_board:

    fn print_board(board: &Vec<usize>, n: usize)
    

标签:求解,board,放置,皇后,queens,col,Rust,row
From: https://blog.csdn.net/gzjimzhou/article/details/143136034

相关文章

  • 在Lua中实现Rust对象的绑定tT
    合集-算法(7)1.TimerWheel(计时轮)在Rust中的实现及源码解析06-122.Rust性能分析之测试及火焰图,附(lru,lfu,arc)测试06-183.Lru-k在Rust中的实现及源码解析06-214.带有ttl的Lru在Rust中的实现及源码解析06-24:westworld加速5.Lfu缓存在Rust中的实现及源码解析06-276.Rust宏之der......
  • 在Lua中实现Rust对象的绑定
    实现目标:能将Rust对象快速的映射到lua中使用,尽可能的简化使用。功能目标以structHcTestMacro为例:类型构建,在lua调用localval=HcTestMacro.new()可构建类型析构,在lua调用HcTestMacro.del(val)可析建,仅限lightuse**rdata字段的映射,假设有字段hc,我们需要能快速的进行字段......
  • uv 基于rust 编写的python 包管理以及项目管理工具
    uv基于rust编写的python包管理以及项目管理工具包含的特性简单工具可以替换pip,pip-tools,pipx,poetry,pyenv等比pip快10-100倍安装以及管理python版本运行以及安装python应用运行脚本支持类似cargo模式的workspace磁盘空间高效说明对于希望提示快速python包下......
  • 【NOIP提高组】一元三次方程求解
    【NOIP提高组】一元三次方程求解......
  • 基于最速下降法和坐标轮换法求解二元函数的极小点和极小值(附word文档)
    基于最速下降法和坐标轮换法求解二元函数的极小点和极小值(附word文档)......
  • 【rCore OS 开源操作系统】Rust 智能指针
    前置知识点何为“智能”在Rust中,“智能指针”是指那些实现了特定智能行为的指针类型。这些智能行为通常包括内存管理、生命周期跟踪以及所有权转移等。常见智能指针BoxBox<T>是Rust中最简单的智能指针类型之一,它用于堆分配的内存。Box<T>允许你在堆上分配类型T......
  • rust操作mysql增删改查
    toml[dependencies]mysql="25.0.0"[[bin]]name="mysql"path="src/mysql.rs"mysql.rsusemysql::*;usemysql::prelude::*;fnmain(){leturl="mysql://root:root@localhost:3306/fiber";letpool=Po......
  • 【智能算法应用】鸭群算法求解二维路径规划问题
    摘要本文研究了鸭群算法在二维路径规划问题中的应用,旨在解决复杂障碍环境下的最优路径搜索问题。通过模拟鸭群觅食行为,鸭群算法能够有效避开障碍物,找到最短路径。实验结果表明,鸭群算法在路径规划中表现出较快的收敛速度和较优的路径规划效果,适用于多种复杂环境下的路径优化......
  • 【智能算法应用】引力搜索算法求解二维路径规划问题
    摘要引力搜索算法(GSA)是一种基于引力学说的启发式算法,用于解决复杂的优化问题。本文应用GSA于二维路径规划问题,通过优化路径来避开障碍物并达到目标点。实验结果表明,GSA在路径规划中具有良好的表现,尤其在多障碍场景中,其优化路径平滑且避障效果显著。理论引力搜索算法是......
  • Rust学习笔记
    首先下载RUST的安装程序:https://www.rust-lang.org/tools/installWindows系统直接下载rustup-init.exe进行安装。这个只是一个安装器,安装的过程中还需要再下载安装文件。下载的速度可能会有点慢。可以尝试设置下面两个系统环境变量(设置在当前用户里)RUSTUP_DIST_SERVER="https:......