洛谷 P2105 K皇后 题解
START:
2021-08-06
16:34:44
题目链接:
https://www.luogu.com.cn/problem/P2105
题目详情:
小 Z 最近捡到了一个棋盘,他想在棋盘上摆放 K 个皇后。他想知道在他摆完这 K 个皇后之后,棋盘上还有多少个格子是不会被攻击到的。
注意:一个皇后会攻击到这个皇后所在的那一行,那一列,以及两条对角线。
输入格式
第一行三个正整数 n,m,K,表示棋盘的行列,以及小 Z 摆放的皇后的个数。
接下来 K 行,每行两个正整数 x,y,表示这个皇后被摆在了第 x行,第 y 列,数据保证任何两个皇后都不会被摆在同一个格子里。
输出格式
仅一个整数,表示棋盘上还有多少个格子是不会被攻击到的。
输入输出样例
12 13 6
10 4
12 10
1 1
2 3
3 2
2 6
25
说明/提示
- 对于 30% 的数据,1≤n,m≤5×10^3,1≤K≤500;
- 对于另外 10% 的数据 K=1;
- 对于 100% 的数据,1≤n,m≤2×10^4,1≤K≤500。
分析:
题目数据有那么亿点点大,所以正经的暴力是不行了,我们每放置一个皇后,用四个数组x[N],y[N],dig[N],udig[N],来储存该皇后
所在的行,列,对角线以及反对角线的状态,我们在图上画一个坐标系,给出任意几个点放置皇后,如下图:

我们可以清楚的看到,点1的横纵坐标为(2,4),当点1放置一个皇后之后,第4行就被全被攻击了,第2列全被攻击,并且x+y=6上的点全被攻击了,以及x-y=-2上的点全被攻击了,所以在点(x,y)出放置一个皇后之后,我们更新所有的数组状态:
x[i]=1,y[j]=1,dig[x+y]=1,udig[x-y+C]=1
这里的udig[x-y+C]中,下标x-y加上常数C的原因是放置数组下标溢出,这就是我们的核心函数了。
在写核心函数之前,我们先写一个初始化函数,将所有的输入处理了
void init(){
for(int i=1;i<=k;i++)
{
int a,b;
scanf("%d%d",&a,&b);
x[a]=1;
y[b]=1;
dig[a+b]=1;
udig[a-b+C]=1;
}
}
接着写核心函数fac()
int fac(){
int res=0;
for(int i=1;i<=n;i++){
if(x[i])continue;
for(int j=1;j<=m;j++){
if(y[j]||dig[i+j]||udig[i-j+C])continue;
else res++;
}
}
return res;
}
最后这几个函数和程序基本框架结合起来
完整代码如下:
(PS:需要开启氧气优化O2优化)
#include<iostream>
#include<cstdio>
using namespace std;
const int N=5e5+10;
const int C=2e4+10;
int n,m,k;
bool x[N],y[N],dig[N],udig[N]; int fac(){
int res=0;
for(int i=1;i<=n;i++){
if(x[i])continue;
for(int j=1;j<=m;j++){
if(y[j]||dig[i+j]||udig[i-j+C])
continue;
else res++;
}
}
return res;
} void init(){
for(int i=1;i<=k;i++)
{
int a,b;
scanf("%d%d",&a,&b);
x[a]=1;
y[b]=1;
dig[a+b]=1;
udig[a-b+C]=1;
}
} int main()
{
cin>>n>>m>>k;
init();
cout<<fac()<<endl;
return 0;
}
end:
2021-08-06
16:59:16
洛谷 P2105 K皇后 题解的更多相关文章
- 洛谷P2105 K皇后
To 洛谷.2105 K皇后 题目描述 小Z最近捡到了一个棋盘,他想在棋盘上摆放K个皇后.他想知道在他摆完这K个皇后之后,棋盘上还有多少了格子是不会被攻击到的. (Ps:一个皇后会攻击到这个皇后所在的 ...
- 洛谷 P2105 K皇后
P2105 K皇后 题目描述 小Z最近捡到了一个棋盘,他想在棋盘上摆放K个皇后.他想知道在他摆完这K个皇后之后,棋盘上还有多少了格子是不会被攻击到的. (Ps:一个皇后会攻击到这个皇后所在的那一行,那 ...
- 洛谷2105 k皇后
P2105 K皇后 题目描述 小Z最近捡到了一个棋盘,他想在棋盘上摆放K个皇后.他想知道在他摆完这K个皇后之后,棋盘上还有多少了格子是不会被攻击到的. (Ps:一个皇后会攻击到这个皇后所在的那一行,那 ...
- 洛谷 P1219 八皇后题解
题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...
- 洛谷P1577 切绳子题解
洛谷P1577 切绳子题解 题目描述 有N条绳子,它们的长度分别为Li.如果从它们中切割出K条长度相同的 绳子,这K条绳子每条最长能有多长?答案保留到小数点后2位(直接舍掉2为后的小数). 输入输出格 ...
- 洛谷P2832 行路难 分析+题解代码【玄学最短路】
洛谷P2832 行路难 分析+题解代码[玄学最短路] 题目背景: 小X来到了山区,领略山林之乐.在他乐以忘忧之时,他突然发现,开学迫在眉睫 题目描述: 山区有n座山.山之间有m条羊肠小道,每条连接两座 ...
- 【洛谷P3960】列队题解
[洛谷P3960]列队题解 题目链接 题意: Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia 所在的方阵中有 n×m ...
- 洛谷P2312 解方程题解
洛谷P2312 解方程题解 题目描述 已知多项式方程: \[a_0+a_1x+a_2x^2+\cdots+a_nx^n=0\] 求这个方程在 \([1,m]\) 内的整数解(\(n\) 和 \(m\) ...
- 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)
洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ...
- 洛谷 P1220 关路灯 题解
Description 有 $n$ 盏路灯,每盏路灯有坐标(单位 $m$)和功率(单位 $J$).从第 $c$ 盏路灯开始,可以向左或向右关闭路灯.速度是 $1m/s$.求所有路灯的最少耗电.输入保证 ...
随机推荐
- linux并行执行线程
资料来源: (1) https://www.jianshu.com/p/d8d58846c53f(作者:黄甫一) 1.并行任务较少时: (1) 给需要并行运行的命令行在结尾加上"&& ...
- java post格式发送application/x-www-form-urlencoded
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import org.apache.http.*; ...
- protobuf笔记
protobuf的enum .proto的enum类型在编译后,是C++的enum
- css布局、动画要点
background属性 属性解释background属性是css中应用比较多,且比较重要的一个属性,它是负责给盒子设置背景图片和背景颜色的,background是一个复合属性,它可以分解成如下几个设 ...
- WPF使用MaterialDesign开源控件库
在WPF控件效果这一块,很显然比winfrom要好很多,但想要做出真正好看的控件,我个人觉得还是需要用一些已有的东西比较好,比如MaterialDesign,控件种类多,自带很多图标,上手比较容易,还 ...
- redhat7
systemctl systemctl enable sshd 开机启动某服务 systemctl disable sshd 开机不启动某服务 systemctl is-enabled sshd查看某 ...
- 手写reduce()
function reduce(arr, callBack ,initVal){ if(!Array.isArray(arr) || !arr.length || typeof callBack != ...
- VisualStudio2015使用C#.NET开发IOS程序时进行真机测试的设置参考
VS2015+Xamarin使用C#.NET开发跨平台APP已经完全可行了,对了WP和UWP程序,都是MS的,一定没有问题. 而对于ANDROID则是直接可以在VS中进行开发.部署到模拟器和真机,非常 ...
- 2022-3-15内部群每日三题-清辉PMP
1.一家公司被一家大公司收购,这家大公司希望把重点放在其核心产品和服务上.处于规划阶段的所有项目都正在进行修定,以包含新的变更管理程序.一个项目的项目经理需要持续的高级输入,以确保与新的组织结构保持一 ...
- Docker 安装流程-CentOS
0.安装Docker Docker 分为 CE 和 EE 两大版本.CE 即社区版(免费,支持周期 7 个月),EE 即企业版,强调安全,付费使用,支持周期 24 个月. Docker CE 分为 s ...