当前位置: 首页 > news >正文

【数据结构入门训练DAY-35】棋盘问题

本次训练聚焦于使用深度优先搜索(DFS)算法解决棋盘上的棋子摆放问题。题目要求在一个可能不规则的n×n棋盘上摆放k个棋子,且任意两个棋子不能位于同一行或同一列。输入包括棋盘大小n和棋子数k,以及棋盘的形状(用#表示可放置区域,.表示空白)。输出为所有可行的摆放方案数C。解题思路是通过DFS遍历棋盘,标记已放置棋子的行和列,递归寻找所有可能的摆放方案,并在回溯时恢复标记。代码实现中,使用二维数组表示棋盘,并通过两个一维数组标记行和列的状态。训练强调了编码习惯的养成和解题思维的训练,为后续学习广度优先搜索(BFS)算法打下基础。

文章目录

  • 前言
  • 一、题目
  • 二、解题思路
  • 总结


前言

本次训练内容

  1. 训练DFS处理棋盘问题。
  2. 对编码习惯的养成。
  3. 训练解题思维。

一、题目

        在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放 k 个棋子的所有可行的摆放方案 C。

输入格式

输入含有多组测试数据。
每组数据的第一行是两个正整数n,k,用一个空格隔开,表示了将在一个n×n的矩阵内描述棋盘,以及摆放棋子的数目。 (n≤8,k≤n)
当为−1−1时表示输入结束。
随后的n行描述了棋盘的形状:每行有n个字符,其中 # 表示棋盘区域,. 表示空白区域(数据保证不出现多余的空白行或者空白列)。

输出格式

对于每一组数据,给出一行输出,输出摆放的方案数目C(数据保证C<231)。

样例输入

2 1
#.
.#
4 4
...#
..#.
.#..
#...
-1 -1

样例输出

2
1

二、解题思路

        今天的题目是一道基础的DFS题,题目就是让我遍历棋盘,找到可以放置棋子的位置并放置对应的棋子,这步倒好做,直接定义标记点即可;然后就是让它递归回溯,标记时要注意正负的顺序。具体实现代码如下:

#include <bits/stdc++.h>
using namespace std;
#define Max 10000
int n,k;
int sum=0;
char Array[Max][Max];
bool check[Max],check1[Max];//创建标记函数void DFS(int x) {if (x==0) {sum++;//计数器return;}for (int i=0;i<n;i++) {for (int j=0;j<n;j++) {if (Array[i][j]=='#'&&check[i]&&check1[j]) {//判断是否可以放置棋子check[i]=check1[j]=false;//标记棋子Array[i][j]='.';//标记位置为不可用DFS(x-1);//递归check[i]=check1[j]=true;//回溯}}}
}
int main() {while (cin>>n>>k&&n!=-1&&k!=-1) {sum=0;for (int i=0;i<n;i++) {for (int j=0;j<n;j++) {cin>>Array[i][j];check[i]=true;//初始都可用check1[j]=true;}}DFS(k);cout<<sum<<endl;}}

        while那里表示循环输入,因为题中说明是通过-1来判断是否结束。 


总结

        今天的题目写起来挺轻松的,没有什么特别难想到的点;这段时间还得多推理一下那些搜索+回溯算法逻辑,这个思维的训练可以让我们更好的掌握DFS算法,进而去学习下一个BFS算法。后续在写题时,还要多注意代码习惯,不能因为一些小错误导致结果错误。

相关文章:

  • Python-Django系列—日志
  • 张 提示词优化(相似计算模式)深度学习中的损失函数优化技巧
  • ES常识9:如何实现同义词映射(搜索)
  • 平滑过滤值策略
  • 时序数据库IoTDB分布式架构解析与运维指南
  • DeepSeek 赋能物联网:从连接到智能的跨越之路
  • 【Pandas】pandas DataFrame diff
  • 语音识别——通过PyAudio录入音频
  • Linux线程控制
  • 【Pandas】pandas DataFrame eval
  • CertiK助力以太坊扩展战略,解析Pectra升级的变革与挑战
  • 5G + 区块链:技术巨浪下的新型数字生态!
  • 数字孪生工厂实战指南:基于Unreal Engine/Omniverse的虚实同步系统开发
  • 如何使用WordPress SEO检查器进行实时内容分析
  • 【OpenGL学习】(一)创建窗口
  • 边缘计算平台
  • Unity光照笔记
  • 如何使用 Google Gemini API 和 Python 从航行情报通告 (NOTAM) 中提取结构化空域信息
  • RiDoc:高效文档扫描与图像处理工具,助力高效办公
  • mavgenerate 在 win11 下环境搭建注意问题
  • 马上评|中学生被操场地面烫伤,谁的“大课间”?
  • 昆明警方重拳打击经济领域违法犯罪:去年抓获905名嫌犯
  • 沪喀同心|为新疆青少年提供科普大餐,“小小博物家(喀什版)”启动
  • 4月企业新发放贷款利率处于历史低位
  • 视频|王弘治:王太后,“先天宫斗圣体”?
  • 气候多米诺:厄尔尼诺与东南亚跨境害虫或威胁中国粮食安全