[NOIP2019模拟赛][AT2381] Nuske vs Phantom Thnook
评测姬好快啊(港记号?)暴力40pts变成60pts
因为题目说了保证蓝色点两两之间只有一条路径,所以肯定组成了一棵树,而对于每次询问的x1,y1,x2,y2的子矩阵中就存在着一个森林
不难知道对于一个森林,其中树(联通块)的数量为$V-E$(V为节点数,E为边数)
也就是说对于每一个询问,只要求出蓝色节点数减去边数的答案就好了
点数和边数都可以用二维前缀和求,其中边可以分横边和竖边分别记录
#pragma GCC optimize("Ofast")
#include<bits/stdc++.h>
using namespace std;
inline int read(){
int ans=,f=;char chr=getchar();
while(!isdigit(chr)){if(chr=='-')f=-;chr=getchar();}
while(isdigit(chr)) {ans=(ans<<)+(ans<<)+chr-;chr=getchar();}
return ans*f;
}const int M = ;
int n,m,Q,s[][],v[][],sx,sy,tx,ty,ans;
int dx[]={,,,-},
dy[]={,,-,};
char a[][];
void dfs(int x,int y){
v[x][y]=;
for(int i=;i<;i++){
int fx=x+dx[i],fy=y+dy[i];
if(v[fx][fy]||fx<sx||fx>tx||fy<sy||fy>ty||a[fx][fy]=='') continue;
dfs(fx,fy);
}
}
inline void BF(){
while(Q--){
memset(v,,sizeof(v));ans=;
sx=read(),sy=read(),tx=read(),ty=read();
for(int i=sx;i<=tx;i++)
for(int j=sy;j<=ty;j++)
if(!v[i][j]&&a[i][j]=='') ans++,dfs(i,j);
printf("%d\n",ans);
}
}int s1[M][M],s2[M][M],s3[M][M];
inline void Solve(){
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
a[i][j]=(a[i][j]=='');
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
s1[i][j]=a[i][j]+s1[i-][j]+s1[i][j-]-s1[i-][j-],
s2[i][j]=(a[i][j]&&a[i+][j])+s2[i-][j]+s2[i][j-]-s2[i-][j-],
s3[i][j]=(a[i][j]&&a[i][j+])+s3[i-][j]+s3[i][j-]-s3[i-][j-];
while(Q--){
sx=read(),sy=read(),tx=read(),ty=read();
int V=s1[tx][ty]-s1[sx-][ty]-s1[tx][sy-]+s1[sx-][sy-];
int E=s2[tx-][ty]-s2[tx-][sy-]-s2[sx-][ty]+s2[sx-][sy-]
+s3[tx][ty-]-s3[sx-][ty-]-s3[tx][sy-]+s3[sx-][sy-];
printf("%d\n",V-E);
}
}
int main(){
freopen("wang.in","r",stdin);
freopen("wang.out","w",stdout);
n=read(),m=read(),Q=read();
for(int i=;i<=n;i++)for(int j=;j<=m;j++)cin>>a[i][j];
// BF();
Solve();
return ;
}
[NOIP2019模拟赛][AT2381] Nuske vs Phantom Thnook的更多相关文章
- AtCoder:C - Nuske vs Phantom Thnook
C - Nuske vs Phantom Thnook https://agc015.contest.atcoder.jp/tasks/agc015_c 题意: n*m的网格,每个格子可能是蓝色, 可 ...
- Nuske vs Phantom Thnook
Nuske vs Phantom Thnook Time limit : 4sec / Memory limit : 256MB Score : 700 points Problem Statemen ...
- 「AT2381 [AGC015C] Nuske vs Phantom Thnook」
题目大意 给出一个01矩阵,这个矩阵有一个特殊的性质: 对于任意两个 \(1\) 之间最多只有 \(1\) 条由 \(1\) 构成的路径.每次询问给出一个矩形范围,查询在这个范围内的联通快个数. 分析 ...
- AGC 015C.Nuske vs Phantom Thnook(思路 前缀和)
题目链接 闻本题有格子,且何谓格子也 \(Description\) 给定\(n*m\)的蓝白矩阵,保证蓝格子形成的的同一连通块内,某蓝格子到达另一个蓝格子的路径唯一. \(Q\)次询问.每次询问一个 ...
- AGC015 C Nuske vs Phantom Thnook(前缀和)
题意 题目链接 给出一张$n \times m$的网格,其中$1$为蓝点,$2$为白点. $Q$次询问,每次询问一个子矩阵内蓝点形成的联通块的数量 保证任意联通块内的任意蓝点之间均只有一条路径可达 S ...
- AtCoder Grand Contest 015 C - Nuske vs Phantom Thnook
题目传送门:https://agc015.contest.atcoder.jp/tasks/agc015_c 题目大意: 现有一个\(N×M\)的矩阵\(S\),若\(S_{i,j}=1\),则该处为 ...
- [agc015c]nuske vs phantom thnook
题意: 有一个n*m的网格图,每个格子是蓝色或白色.四相邻的两个格子连一条边,保证蓝格子构成一个森林. 有q组询问,每次询问给出一个矩形,问矩形内蓝格子组成的联通块个数. $1\leq n,m\leq ...
- Atcoder C - Nuske vs Phantom Thnook(递推+思维)
题目链接:http://agc015.contest.atcoder.jp/tasks/agc015_c 题意:给一个n*m的格,蓝色的组成路径保证不成环,q个询问,计算指定矩形区域内蓝色连通块的个数 ...
- test20190827 NOIP2019 模拟赛
100+100+50=250.最后那道期望题需要用另外的方式统计. 精灵加护 ljss 被 M 个敌人打倒在地上啦!每个敌人有一个威力值 bi.但是他手中还拥有 N 把武器!每把武器有一个威力值 ai ...
随机推荐
- NX二次开发-UFUN按类型遍历名字获取Tag函数UF_OBJ_cycle_by_name_and_type
NX9+VS2012 #include <uf.h> #include <uf_draw.h> #include <uf_obj.h> #include <u ...
- (转) mysql的分区技术 .
转:http://blog.csdn.net/feihong247/article/details/8100960 一.概述 当 MySQL的总记录数超过了100万后,会出现性能的大幅度下降吗?答案是 ...
- hdu多校第六场1012 (hdu6645) Stay Real 假博弈,真贪心
题意: 给你一个小根堆,从根开始拿,拿走子节点被拿完后才可以拿走父节点,两个人依次拿,谁拿的节点总和大谁获胜,问你谁有必胜策略. 题解: 小根堆中,每个点的权值总是不小于父亲节点的权值.所以无论怎么取 ...
- 微信-小程序-开发文档-服务端-模板消息:templateMessage.send
ylbtech-微信-小程序-开发文档-服务端-模板消息:templateMessage.send 1.返回顶部 1. templateMessage.send 本接口应在服务器端调用,详细说明参见服 ...
- ionic-CSS:ionic tab(选项卡)
ylbtech-ionic-CSS:ionic tab(选项卡) 1.返回顶部 1. ionic tab(选项卡) ionic tab(选项卡) 是水平排列的按钮或者链接,用以页面间导航的切换.它可以 ...
- 剑指offer——25合并两个排序的链表
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 题解: 使用普通方法,或者递归,注意新的头节点即可. //使用普通的合并方法 class S ...
- jq页面换肤效果
<!DOCTYPE html> <html lang="en"> <head> <script src="http://code ...
- 本地 win7 与虚拟机Centos7 ping互通和Centos7 上网设置
VM 12 安装虚拟机我就不表示了 很简单网上找找 一 .虚拟机设置 1.修改使用了 VMWare 12 虚拟机,Oracle VM 用得有点晕 2.配置VM 的NET环境 3.在VMware虚拟机任 ...
- Python:获取当前py的文件名
采用pathlib库 from pathlib import Path Path(__file__).name
- java获得磁盘、网络实时I/O速率
最近项目中需要一个平台硬件资源的监控模块,当时采用了Sigar中api,但是做到针对磁盘和网络的实时I/O速率的时候发现Sigar并没有直接支持的接口.于是……它就诞生了.底层采用C++编写,通过ja ...