题目链接

评测姬好快啊(港记号?)暴力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的更多相关文章

  1. AtCoder:C - Nuske vs Phantom Thnook

    C - Nuske vs Phantom Thnook https://agc015.contest.atcoder.jp/tasks/agc015_c 题意: n*m的网格,每个格子可能是蓝色, 可 ...

  2. Nuske vs Phantom Thnook

    Nuske vs Phantom Thnook Time limit : 4sec / Memory limit : 256MB Score : 700 points Problem Statemen ...

  3. 「AT2381 [AGC015C] Nuske vs Phantom Thnook」

    题目大意 给出一个01矩阵,这个矩阵有一个特殊的性质: 对于任意两个 \(1\) 之间最多只有 \(1\) 条由 \(1\) 构成的路径.每次询问给出一个矩形范围,查询在这个范围内的联通快个数. 分析 ...

  4. AGC 015C.Nuske vs Phantom Thnook(思路 前缀和)

    题目链接 闻本题有格子,且何谓格子也 \(Description\) 给定\(n*m\)的蓝白矩阵,保证蓝格子形成的的同一连通块内,某蓝格子到达另一个蓝格子的路径唯一. \(Q\)次询问.每次询问一个 ...

  5. AGC015 C Nuske vs Phantom Thnook(前缀和)

    题意 题目链接 给出一张$n \times m$的网格,其中$1$为蓝点,$2$为白点. $Q$次询问,每次询问一个子矩阵内蓝点形成的联通块的数量 保证任意联通块内的任意蓝点之间均只有一条路径可达 S ...

  6. AtCoder Grand Contest 015 C - Nuske vs Phantom Thnook

    题目传送门:https://agc015.contest.atcoder.jp/tasks/agc015_c 题目大意: 现有一个\(N×M\)的矩阵\(S\),若\(S_{i,j}=1\),则该处为 ...

  7. [agc015c]nuske vs phantom thnook

    题意: 有一个n*m的网格图,每个格子是蓝色或白色.四相邻的两个格子连一条边,保证蓝格子构成一个森林. 有q组询问,每次询问给出一个矩形,问矩形内蓝格子组成的联通块个数. $1\leq n,m\leq ...

  8. Atcoder C - Nuske vs Phantom Thnook(递推+思维)

    题目链接:http://agc015.contest.atcoder.jp/tasks/agc015_c 题意:给一个n*m的格,蓝色的组成路径保证不成环,q个询问,计算指定矩形区域内蓝色连通块的个数 ...

  9. test20190827 NOIP2019 模拟赛

    100+100+50=250.最后那道期望题需要用另外的方式统计. 精灵加护 ljss 被 M 个敌人打倒在地上啦!每个敌人有一个威力值 bi.但是他手中还拥有 N 把武器!每把武器有一个威力值 ai ...

随机推荐

  1. NX二次开发-C++time函数计时

    NX11+VS2013 #include <uf.h> #include <uf_modl.h> #include <uf_ui.h> #include <t ...

  2. iOS 多层级的immutable objects 转换成 mutable objects

    第一种方法是:将多层级的递归转换 方法: +(id) recursiveMutable:(id)object { if([object isKindOfClass:[NSDictionary clas ...

  3. $nextTick与nextTick

    $nextTick Data-Dom-之后回调 nextTick Data-回调-Dom

  4. java发送http的get/post请求(一)

    HTTP请求类 import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; ...

  5. abstract类中method

    一.abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized? 都不可以,因为abstract申明的方法是要求子类去实现的,abstrac ...

  6. dubbo jar 配置文件

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  7. PL/SQL跨库查询数据

    步骤一:找到Database links  (新建) 步骤二:正确填写完对应信息 (应用) : 步骤三:执行PL/SQL语句(完成) select * from tablename@MYDATA 注释 ...

  8. 软件设计师_朴素模式匹配算法和KMP算法

    1.从主字符串中匹配模式字符串(暴力匹配) 2. KMP算法

  9. 一张图轻松掌握 Flink on YARN 应用启动全流程(上)

    Flink 支持 Standalone 独立部署和 YARN.Kubernetes.Mesos 等集群部署模式,其中 YARN 集群部署模式在国内的应用越来越广泛.Flink 社区将推出 Flink ...

  10. kubernetes istio的快速安装和使用例子

    安装 [root@master ~]# wget https://github.com/istio/istio/releases/download/1.1.5/istio-1.1.5-linux.ta ...