【回溯专题】【蓝桥杯备考训练】:n-皇后问题、木棒、飞机降落【未完待续】

目录

1、n-皇后问题(回溯模板)

2、木棒(《算法竞赛进阶指南》、UVA307)

3、飞机降落(第十四届蓝桥杯省赛C++ B组)


1、n-皇后问题(回溯模板)

n皇后问题是指将 n 个皇后放在 n×n 的国际象棋棋盘上,使得皇后不能相互攻击到,即任意两个皇后都不能处于同一行、同一列或同一斜线上。

1_597ec77c49-8-queens.png

现在给定整数 n,请你输出所有的满足条件的棋子摆法。

输入格式

共一行,包含整数 n。

输出格式

每个解决方案占 n 行,每行输出一个长度为 n的字符串,用来表示完整的棋盘状态。

其中 . 表示某一个位置的方格状态为空,Q 表示某一个位置的方格上摆着皇后。

每个方案输出完成后,输出一个空行。

注意:行末不能有多余空格。

输出方案的顺序任意,只要不重复且没有遗漏即可。

数据范围

1≤n≤9

输入样例:
4
输出样例:
.Q..
...Q
Q...
..Q...Q.
Q...
...Q
.Q..
思路:

经典的模板,这里的u代表行、col数组用来枚举标记列、dg用来枚举标记对角线、undg用来标记反对角线

代码:
#include<bits/stdc++.h>using namespace std;int n;const int N=10;char g[N][N];bool col[N],dg[N],undg[N];void dfs(int u)
{if(u==n)//找到一种方案 {for(int i=0;i<n;i++)puts(g[i]);puts("");return ;}for(int i=0;i<n;i++)//枚举列 {if(!col[i]&&!dg[u+i]&&!undg[u-i+n]){g[u][i]='Q';col[i]=dg[u+i]=undg[u-i+n]=true;dfs(u+1);col[i]=dg[u+i]=undg[u-i+n]=false;g[u][i]='.';}}
}
int main()
{cin>>n;for(int i=0;i<n;i++)for(int j=0;j<n;j++)g[i][j]='.';dfs(0);return 0;	
} 

2、木棒(《算法竞赛进阶指南》、UVA307)

乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过 50 个长度单位。

然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度。

请你设计一个程序,帮助乔治计算木棒的可能最小长度。

每一节木棍的长度都用大于零的整数表示。

输入格式

输入包含多组数据,每组数据包括两行。

第一行是一个不超过 64 的整数,表示砍断之后共有多少节木棍。

第二行是截断以后,所得到的各节木棍的长度。

在最后一组数据之后,是一个零。

输出格式

为每组数据,分别输出原始木棒的可能最小长度,每组数据占一行。

数据范围

数据保证每一节木棍的长度均不大于 50。

输入样例:
9
5 2 1 5 2 1 5 2 1
4
1 2 3 4
0
输出样例:
6
5
思路:
关键剪枝条件:

1、如果上一次最终没有满足条件,回溯出来后如果我们还在拼第一根(cur==0),那么必定失败

2、如果上一次失败回溯出来后,我们正好满足现在的长度加上当前木棍长度==目标长度(cur+a[i]==len),那么必定失败

3、我们要跳过和当前长度相同的木棍,因为用这个长度必定失败

代码:
#include<bits/stdc++.h>using namespace std;const int N=70;int n;int len,sum;
int a[N];
bool st[N];//记录状态 
//cur表示当前的长度
//u表示拼接的个数 
//start表示从第几根开始拼 
bool dfs(int u,int cur,int start)
{if(u*len==sum)return true;//拼成所有的 if(cur==len)return dfs(u+1,0,0);for(int i=start;i<n;i++){if(st[i])continue;if(cur+a[i]<=len){st[i]=true;//表示第i根已经用过了 if(dfs(u,cur+a[i],i+1))return true;st[i]=false;}if(!cur || cur+a[i]==len)return false;//如果当前在拼新木棍或者是最后一根品好的木棍 int j=i+1;while(j<n && a[j]==a[i])j++;//跳过长度相同的木棍 i=j-1;}return false;
}int main()
{while(cin>>n,n!=0){len=sum=0;memset(st,false,sizeof st);for(int i=0;i<n;i++){cin>>a[i];	sum+=a[i];len=max(len,a[i]);} sort(a,a+n,greater<int>());while(true){if(sum%len==0 && dfs(0,0,0)){cout<<len<<endl;break;}len++;}}return 0;	
} 

3、飞机降落(第十四届蓝桥杯省赛C++ B组)

有 N 架飞机准备降落到某个只有一条跑道的机场。

其中第 i 架飞机在 Ti时刻到达机场上空,到达时它的剩余油料还可以继续盘旋 Di 个单位时间,即它最早可以于 Ti 时刻开始降落,最晚可以于 Ti+Di 时刻开始降落。

降落过程需要 Li个单位时间。

一架飞机降落完毕时,另一架飞机可以立即在同一时刻开始降落,但是不能在前一架飞机完成降落前开始降落。

请你判断 N 架飞机是否可以全部安全降落。

输入格式

输入包含多组数据。

第一行包含一个整数 T,代表测试数据的组数。

对于每组数据,第一行包含一个整数 N。

以下 N 行,每行包含三个整数:Ti,Di 和 Li。

输出格式

对于每组数据,输出 YES 或者 NO,代表是否可以全部安全降落。

数据范围

对于 30% 的数据,N≤2。
对于 100% 的数据,1≤T≤10,1≤N≤10,0≤Ti,Di,Li≤1e5。

输入样例:
2
3
0 100 10
10 10 10
0 2 20
3
0 10 20
10 10 20
20 10 20
输出样例:
YES
NO
样例解释

对于第一组数据,可以安排第 3 架飞机于 0 时刻开始降落,20 时刻完成降落。安排第 2 架飞机于 20时刻开始降落,30 时刻完成降落。安排第 1 架飞机于 30 时刻开始降落,40 时刻完成降落。

对于第二组数据,无论如何安排,都会有飞机不能及时降落。

思路:

关键:我们飞机最可以降落的最早时间是max(last,t)+l,因为就算飞机可以降落了,上一个飞机没有降落完成也是不行的,必须等到last结束才能降落,所以上上一辆飞机降落的时间取为max(last,t)+l

代码:
#include<bits/stdc++.h>using namespace std;const int N=20;struct plane
{int t,d,l;
}p[N]; int k,n;
int t[N],d[N],l[N];
bool st[N];//bool cmp(plane a,plane b)
//{
//	return a.t<b.t;
//}bool dfs(int cnt,int last)
{if(cnt>=n)//飞机达到数量 {return true;}for(int i=0;i<n;i++){int t=p[i].t;int d=p[i].d;int l=p[i].l;if(!st[i] && t+d>=last){st[i]=true;if(dfs(cnt+1,max(last,t)+l))return true;st[i]=false;}}return false;
}int main()
{cin>>k;while(k--){cin>>n;for(int i=0;i<n;i++){int a,b,c;scanf("%d%d%d",&a,&b,&c);p[i]={a,b,c};}memset(st,false,sizeof st);if(dfs(0,0))cout<<"YES"<<endl;else cout<<"NO"<<endl;}return 0;	
} 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/751573.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用户视角的比特币和以太坊外围技术整理

1. 引言 要点&#xff1a; 比特币L2基本强调交易内容的隐蔽性&#xff0c;P2P交易&#xff08;尤其是支付&#xff09;成为主流&#xff0c;给用户带来一定负担&#xff08;闪电网络&#xff09;在以太坊 L2 中&#xff0c;一定程度上减少了交易的隐蔽性&#xff0c;主流是实…

-bash-4.2$

CentOS 出现-bash-4.2$ 1原因2解决办法 1原因 使用CentOS7时&#xff0c;出现了-bash-4.2$&#xff0c;而不再是usernamelocalhost格式&#xff0c;是因为用户路径/home/username下的配置文件丢失了。 .bashrc .bash_profile2解决办法 复制配置文件到用户目录下。 cp /etc/…

27-3 文件上传漏洞 - 文件类型绕过(后端绕过)

环境准备:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客 导语 后端校验由开发决定是检测文件后缀,还是文件内容。 文件类型绕过(Content-Type) 1)MIME 类型 定义:MIME(Multipurpose Internet Mail Extensions)类型是一种标准,…

数据资产管理之道:PDCA循环引领数字化转型

在数字化浪潮的推动下&#xff0c;数据已成为现代企业的核心竞争力。如何有效地管理这些宝贵的数据资产&#xff0c;确保它们为企业带来持续的竞争优势&#xff0c;成为许多企业迫切需要解决的问题。本文将基于PDCA循环&#xff0c;为您深入剖析如何构建稳健的数据资产管理流程…

Tailwind CSS如何使用

Tailwind CSS 是一个功能类优先的 CSS 框架&#xff0c;它提供了大量的实用工具类&#xff0c;使得在 HTML 文件中直接通过类组合的方式来构建设计而不需要写自定义 CSS。这种方法提供了极高的灵活性和定制性&#xff0c;同时也极大地加快了开发速度。自从它在 2017 年被首次发…

【方法封装】时间格式化输出,获取请求设备和IP

目录 时间类 1.1 获取当前时间&#xff0c;以特定格式化形式输出 1.2 自定义时间&#xff0c;以特定格式化输出 1.3 获取当前时间&#xff0c;自定义格式化 1.4 自定义时间&#xff0c;自定义格式化 设备类 根据请求头信息&#xff0c;获取用户发起请求的设备 请求IP类 …

DVWA靶场-Brute Force暴力破解

DVWA是一个适合新手锻炼的靶机&#xff0c;是由PHP/MySQL组成的 Web应用程序&#xff0c;帮助大家了解web应用的攻击手段 DVWA大致能分成以下几个模块&#xff0c;包含了OWASP Top 10大主流漏洞环境。 Brute Force——暴力破解 Command Injection——命令注入 CSRF——跨站请…

解决找不到d3dx9_42.dll,无法继续执行此代码的多种方法

在计算机使用过程中&#xff0c;我们常常会遇到一些错误提示&#xff0c;其中之一就是“d3dx942.dll丢失”。这个错误通常出现在运行某些游戏或应用程序时&#xff0c;它会导致程序无法正常运行。为了解决这个问题&#xff0c;我们需要采取一些措施来修复丢失的d3dx942.dll文件…

[Golang]K-V存储引擎的学习 从零实现 (RoseDB mini版本)

文章目录 项目的简单介绍详情 代码分析项目结构db.godb_file.goentry.go 项目的简单介绍 对mini-bitcask的学习,从零实现一个k-v存储引擎 原项目的github地址,感谢Rose大佬 mini-bitcask为rosedb的mini版本&#xff0c;博主借此了解k-v存储,该项目通过对一个数据文件进行读写以…

2024年腾讯云免费服务器4核8G配置申请

腾讯云免费服务器4核8G配置申请入口 https://curl.qcloud.com/FJhqoVDP 免费服务器可选轻量应用服务器和云服务器CVM&#xff0c;轻量配置可选2核2G3M、2核8G7M和4核8G12M&#xff0c;CVM云服务器可选2核2G3M和2核4G3M配置&#xff0c;腾讯云服务器网txyfwq.com分享2024年最新腾…

如何在webapp中手动部署

前言&#xff1a;这个有不知道怎么下载Tomcat的可以看我这篇博客的前面&#xff0c;有相关链接&#xff0c;下载好后我那边也有如何运行成功的 在idea中配置tomcat服务器&#xff0c;部署一个项目-CSDN博客 接下来进入这篇博客的正题&#xff01;怎么手动部署 先找到我们下载…

【业务功能篇145】Spring项目中线程池实战应用各种场景ThreadPoolTaskExecutor

【业务功能篇 142】多线程池Semaphore信号量 数据并行处理-CSDN博客 【业务功能篇135】多线程countDownLatch执行大数据量定时任务_countdownlantch 实现多个线程开始执行任务的最大并行性-CSDN博客 线程池ThreadPoolTaskExecutor实战-CSDN博客 springboot线程池ThreadPoo…

每日GEE| Day 01 研究区域矢量数据加载

// Add study region var roi ee.FeatureCollection(geometry) Map.centerObject(roi,8); var styling {color:red,fillColor:00000000,width:2};// display hollow roi Map.addLayer(roi.style(styling), {}, "outline"); 以上代码的功能实现了对研究区域的加载&am…

C语言如何初始化⼆维数组?

一、问题 ⼆维数组怎样初始化&#xff0c;有⼏种⽅法&#xff1f; 二、解答 ⼆维数组和⼀维数组⼀样&#xff0c;也可以在声明时对其进⾏初始化。⼆维数组的初始化⽅式⽐⼀维数组较为复杂&#xff0c;但都是由⼀维数组初始化⽅法⾏⽣⽽来的。在给⼆维数组赋初值时&#xff0c;…

Java零基础入门-如何代码模拟斗地主洗牌发牌动作(上)?

一、本期教学目标 掌握map集合常用方法。掌握map集合使用场景。通过map集合实现斗地主洗牌发牌动作。 二、前言 对于双列集合之map集合&#xff0c;它的相关知识点及拓展咱们都已经差不多学完了。接下来&#xff0c;就是带着大家如何灵活运用map进行一个实战教学&#xff0c;…

阿联酋将资助 OpenAI 的内部芯片

据《金融时报》报道&#xff0c;OpenAI计划开发自己的半导体芯片&#xff0c;以支持高级AI模型的野心可能会从阿拉伯联合酋长国&#xff08;UAE&#xff09;获得支持。 报道称&#xff0c;阿布扎比的国家支持集团MGX正在讨论支持OpenAI的内部构建AI芯片的计划。这一信息来自于…

FFmpeg-aac、h264封装flv及时间转换

文章目录 时间概念流程api核心代码 时间概念 dts: 解码时间戳, 表示压缩帧的解码时间 pts: 显示时间戳, 表示将压缩帧解码后得到的原始帧的显示时间 时间基: time_base &#xff0c; 通常以ms为单位 时间戳: timestamp , 多少个时间基 真实时间&#xff1a;time_base * timest…

如何设计高并发系统

1.局部并发原则 复杂的业务&#xff0c;把不相关的用异步执行&#xff0c;这样的话有几个问题&#xff1a;1.第一个一步失败了&#xff0c;本来不用执行后面的逻辑&#xff0c;现在改成异步&#xff0c;无法 控制&#xff0c;增加数据库的压力。性能本来就是资源换时间嘛&#…

力扣111---二叉树的最小深度(简单题,Java,递归+非递归)

目录 题目描述&#xff1a; &#xff08;递归&#xff09;代码&#xff1a; &#xff08;非递归、层次遍历&#xff09;代码&#xff1a; 题目描述&#xff1a; 给定一个二叉树&#xff0c;找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说…

ping和telnet的区别

ping是ICMP协议&#xff0c;只包含控制信息没有端口&#xff0c;用于测试两个网络主机之间网络是否畅通 telnet是TCP协议&#xff0c;用于查看目标主机某个端口是否开发。 总结&#xff1a;ping是物理计算机间的网络互通检查&#xff0c;telnet是应用服务间的访问连通检查&am…