[kuangbin带你飞]专题一 简单搜索 A - 棋盘问题

2024-03-22 18:40

本文主要是介绍[kuangbin带你飞]专题一 简单搜索 A - 棋盘问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简单的DFS,不过还是挺开心的!
哈哈!
POJ宕机了,在OpenJ_Bailian上提交的( https://vjudge.net/problem/OpenJ_Bailian-1321 )

可以先看一下N皇后问题再做这道题,N皇后问题最初是八皇后问题,很经典的问题,可以百度一下背景故事,蛮好玩的:

题目:
https://vjudge.net/problem/HDU-2553

题解:
N皇后问题(DFS) HDU - 2553【详记】: https://blog.csdn.net/qq_41246972/article/details/86768920
N皇后问题的两个最高效的算法: https://blog.csdn.net/hackbuteer1/article/details/6657109

另外不太懂DFS或者递归思想的,可以试着用递归写个代码输出组合(例如输入3,输出123,1,2,3,12,13,23),就是排列组合中的组合,应该对理解这种思想有帮助:

1、使用DFS(深搜)遍历所有的序列所有的子组合(子序列)(排列组合中的组合)https://blog.csdn.net/qq_41246972/article/details/86750594

2、DFS——组合与排列
https://blog.csdn.net/cqbzlytina/article/details/78646018#枚举组合combination

以下是我的AC代码

速度还可以:
在这里插入图片描述

#include<vector> 
#include<string>
#include<utility>
#include<iostream>
using namespace std;
int n,k,ans,put[8+1],vec_size,put_1[8+1],re=1;  
vector<pair<int,int>> chess_position;
bool is_here_ok(int line,int row)
{ for(int i=0;i<line;i++) if(put[i]==row) return false;return true;
}
void dfs(int line,int i)
{if(line==k){ans++;return;} for(;i<vec_size;i++)if(chess_position[i].first!=put_1[line-1]||(chess_position[i].first==0&&re))if(is_here_ok(line,chess_position[i].second)){re=0;put[line]=chess_position[i].second;put_1[line]=chess_position[i].first;dfs(line+1,i+1); }re=1;return;
}
void solve()
{for(int i=0;i<n;i++){string input;cin>>input;getchar();for(int j=0;input[j];j++)if(input[j]=='#') {pair<int,int> res (i,j);chess_position.push_back(res);}  } vec_size=chess_position.size(); dfs(0,0);cout<<ans<<endl; return;
}
int main()
{while(true){cin>>n>>k;getchar();if(n==-1||k==-1) return 0;ans=0;solve();chess_position.clear(); } 
} 

哈哈,毕竟是部落格嘛!主要还是日志、记录为主,题解为辅,索性把草稿纸也拍上来,BLOG嘛
?

在这里插入图片描述

这篇关于[kuangbin带你飞]专题一 简单搜索 A - 棋盘问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/835960

相关文章

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

关于Nginx跨域问题及解决方案(CORS)

《关于Nginx跨域问题及解决方案(CORS)》文章主要介绍了跨域资源共享(CORS)机制及其在现代Web开发中的重要性,通过Nginx,可以简单地解决跨域问题,适合新手学习和应用,文章详细讲解了CO... 目录一、概述二、什么是 CORS?三、常见的跨域场景四、Nginx 如何解决 CORS 问题?五、基

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss