Codeforces1303F Number of Components
Description
题意:给一个全\(0\)矩阵,每次支持一个修改,修改不还原(这要是还原了不就成\(A\)题了)
然后询问每一次修改完了当前矩阵的连通块个数
每一个修改的值单调不降
修改次数 \(\leq 10^6\)
Solution
这个是一道并查集题(感觉我原来从来没有写过任何并查集维护信息的题目)
具体就是我们对于每一个修改要考虑的是这个修改带来的贡献,就是和相邻颜色的对比
能合并的就合并一下,然后统计答案
这时,我们把这个题转化成了对每一种颜色考虑,然后看这个颜色的改变(最后开个桶就成了)
对于每种颜色,会有两种:添加一个颜色(正序处理),颜色被覆盖(逆序处理)
逆序的原因是被覆盖的时候原先有的这个连通块可能被整成多个连通块
(如果我们逆序处理覆盖,就等同于正序处理添加,贡献相减即可)
真是一道并查集应用的不错题目
Code
#include<bits/stdc++.h>
using namespace std;
#define int long long
namespace yspm{
inline int read()
{
int res=0,f=1; char k;
while(!isdigit(k=getchar())) if(k=='-') f=-1;
while(isdigit(k)) res=res*10+k-'0',k=getchar();
return res*f;
}
const int N=310,Q=2e6+10;
int fx[4]={0,-1,1,0},fy[4]={-1,0,0,1};
int n,m,q,maxx,ans[Q],fa[N*N],now[N][N];
struct query{int id,x,y;}; vector<query>q1[Q],q2[Q];
inline int num(int x,int y){return (x-1)*m+y;}
inline int rt(int x){return fa[x]==x?x:fa[x]=rt(fa[x]);}
inline bool in(int x,int y){return x>0&&x<=n&&y>0&&y<=m;}
inline void clear(int n){for(int i=1;i<=n;++i) fa[i]=i; return ;}
inline bool merge(int x,int y){x=rt(x),y=rt(y); if(x==y) return 0; return fa[x]=y,1;}
signed main()
{
n=read(); m=read(); q=read();
for(int i=1,x,y,c;i<=q;++i)
{
x=read(),y=read(),c=read(); maxx=c;
q2[now[x][y]].push_back((query){i,x,y});
q1[now[x][y]=c].push_back((query{i,x,y}));
}
for(int i=1;i<=n;++i)
{
for(int j=1;j<=m;++j) q2[now[i][j]].push_back((query){0,i,j});
}memset(now,-1,sizeof(now));
for(int i=0,sz,id,x,y;i<=maxx;++i)
{
sz=q1[i].size(); if(!sz) continue; clear(n*m);
for(int j=0;j<sz;++j)
{
id=q1[i][j].id; x=q1[i][j].x; y=q1[i][j].y;
now[x][y]=i; ++ans[id];
for(int k=0;k<4;++k)
{
int tx=x+fx[k],ty=y+fy[k];
if(in(tx,ty)&&now[tx][ty]==i) ans[id]-=merge(num(x,y),num(tx,ty));
}
}
}memset(now,-1,sizeof(now));
for(int i=0,sz,id,x,y;i<=maxx;++i)
{
sz=q2[i].size(); if(!sz) continue; clear(n*m);
for(int j=sz-1;j>=0;--j)
{
id=q2[i][j].id; x=q2[i][j].x; y=q2[i][j].y;
now[x][y]=i; --ans[id];
for(int k=0;k<4;++k)
{
int tx=x+fx[k],ty=y+fy[k];
if(in(tx,ty)&&now[tx][ty]==i) ans[id]+=merge(num(x,y),num(tx,ty));
}
}
}
ans[0]=1; for(int i=1;i<=q;++i) printf("%lld\n",ans[i]+=ans[i-1]);
return 0;
}
}
signed main(){return yspm::main();}
Codeforces1303F Number of Components的更多相关文章
- 【CF1151E】Number of Components
[CF1151E]Number of Components 题面 CF 题解 联通块个数=点数-边数. 然后把边全部挂在较小的权值上. 考虑从小往大枚举左端点,等价于每次删掉一个元素,那么删去点数,加 ...
- CodeForces 1151E Number of Components
题目链接:http://codeforces.com/problemset/problem/1151/E 题目大意: n个人排成一个序列,标号为 1~n,第 i 个人的学习成绩为 ai,现在要选出学习 ...
- Codefores 1151E Number of Components
大意:给定n元素序列$a$, $1\le a_i \le n$, 定义函数$f(l,r)$表示范围在$[l,r]$以内的数构成的连通块个数, 求$\sum\limits_{i=1}^{n}\sum\l ...
- cf1151e number of components
很常见的思想:将整体求改为统计每个部分的贡献 本题中统计[l, r]时, 每个连通块有一个重要特征, 最右端的数在[l,r]中而下一个数不在(好像是句废话 那么我们分别考虑每个点对连通块的贡献, 即它 ...
- [CF1303F] Number of Components - 并查集,时间倒流
有一个 \(n \times m\) 矩阵,初态下全是 \(0\). 如果两个相邻元素(四连通)相等,我们就说它们是连通的,且这种关系可以传递. 有 \(q\) 次操作,每次指定一个位置 \((x_i ...
- Codeforces 1270H - Number of Components(线段树)
Codeforces 题目传送门 & 洛谷题目传送门 首先需发现一个性质,那就是每一个连通块所对应的是一个区间.换句话说 \(\forall l<r\),若 \(l,r\) 在同一连通块 ...
- [翻译]Writing Custom Report Components 编写自定义报表组件
摘要:简单介绍了如何编写一个FastReport的组件,并且注册到FastReport中使用. Writing Custom Report Components 编写自定义报表组件 FastRep ...
- OpenCV人脸识别Eigen算法源码分析
1 理论基础 学习Eigen人脸识别算法需要了解一下它用到的几个理论基础,现总结如下: 1.1 协方差矩阵 首先需要了解一下公式: 共公式可以看出:均值描述的是样本集合的平均值,而标准差描述的则是样本 ...
- SDWebImage源码解读_之SDWebImageDecoder
第四篇 前言 首先,我们要弄明白一个问题? 为什么要对UIImage进行解码呢?难道不能直接使用吗? 其实不解码也是可以使用的,假如说我们通过imageNamed:来加载image,系统默认会在主线程 ...
随机推荐
- C++基础--引用做函数参数
引用,简单粗暴的解释叫做别名,简单粗暴的例子就是,我是熊叫大雄,但是很多时候别人不叫我熊叫大雄,会叫我大雄,粤语地区朋友爱叫我阿雄,有人叫我雄,所以,熊叫大雄这个变量的值是我,雄.大雄.阿雄是熊叫大雄 ...
- 全面掌握Nginx配置+快速搭建高可用架构 一 Nginx的访问控制
语法 示例 allow 127.0.0.1; deny all; 缺点:局限性 如果通过代理就可以绕过访问限制,限制不准确 解决 1. http_x_forwarded_for 2. 结合geo模块作 ...
- ES6的一些语法
let, const, class, extends, super, arrow functions, template string, destructuring, default, rest ar ...
- Codeforces 1290A/1291C - Mind Control
题目大意: 总共有n个人和n个数字 n个人拍成一队,n个数字也是有顺序的 你排在第m个位置 按照顺序的每个人可以拿走这个序列中的第一个数字或者最后一个数字 你可以在所有人操作开始前说服最多k个人 让他 ...
- Thread--CountDownLatch & CyclicBarrier
参考:http://www.importnew.com/21889.html CountDownLatch countDown() 方法执行完只是计数器减一, 并不会阻塞当前运行线程的的后续代码执行. ...
- 题解 P1654 【OSU!】
题面 一序列\(a\), 对于每一个\(i\)均有\(a_i\)有\(p_i\)的几率为1, 否则为\(0\) 求: \(a\)中极长全\(1\)子序列长度三次方之和的期望 前置知识 基本期望(期望的 ...
- SpringCloud学习之手把手教你用IDEA搭建入门项目【番外篇】(一)
之前的文章里,我曾经搭建了一个Springcloud项目,但是那个时候我对于SpringCloud架构的很多组件不甚清楚,只是通过查找资料然后动手稀里糊涂的把一个项目成功搭建起来了,其中有很多不合理和 ...
- .NET 软件下面win10自动启动配置
1.设置所有用户登录都能启动,打开文件夹 C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp 2.给要启动的应用程序创建快捷方式, ...
- request对象和response对象的作用和相关方法
response对象(响应) 响应行 状态码 :setStatus(int a) 设置状态码 302重定向 304控制缓存 响应头 setHeader() 一个key对应一个value addHead ...
- 开发大型项目必备 98%公司都在用的十佳 Java Web 应用框架
众所周知,工欲善其事,必先利其器.选择一个好的 Web 应用框架就像一把称手的兵器,可以助大家披荆斩棘. 今天就为大家整理了十佳 Java Web 应用框架,并简单讨论一下它们的优缺点. 第一,大名鼎 ...