【题解】CF1592F-Alice and Recoloring

技术【题解】CF1592F-Alice and Recoloring 【题解】CF1592F-Alice and Recoloring很神的思维题。
观察以下发现对于矩阵取反非常不好做。
这时候我们可以

【题解】cf 1592 f-爱丽丝和重新着色

很神的思维题。

观察以下发现对于矩阵取反非常不好做。

这时候我们可以联想到差分,将它转化为单点取反。

所以我们构造广义差分数组\(a_{i,j}=s_{i,j}\oplus s_{i 1,j}\oplus s_{i,j 1}\oplus s_{i 1,j 1}\)。原矩阵\(s\)全\(0\) 等价于矩阵\(a\)全\(0\)。

手算以下发现\(1,2,3\) 操作对应单点取反,\(4\) 操作对应\(4\) 个点取反。

所以对于\(F1\)题,\(4\) 操作最多只会进行一次,枚举以下即可。

对于\(F2\)题,一个位置除了\((n,m)\)只会翻转一次,且尽量先用\(4\) 操作,所以直接套二分图模型即可。

#定义编号505

整数N,m,a[N][N],u[N][N];字符s[N];

int main(){ 0

//int T=read();while(T-)solve();

n=read(),m=read();

代表(I,1,n){ 0

scanf("% s ",S1);

rep(j,1,m)a[I][j]=s[j]==' B ';

}

int ans=0;

rep(i,1,n)rep(j,1,m)ans=(u[I][j]=a[i][j]^ a[I 1][j]^ a[I][j 1]^ a[I 1][j 1]);

if(u[n][m])

rep(i,1,n - 1)rep(j,1,m - 1)if(u[i][j] u[n][j] u[i][m])

printf('%d\n ',ans-1);返回0;

}

printf('%d\n ',ans);

返回0;

}

#定义编号505

int n,m,u[N][N],a[N][N],s,t;字符w[N];

int h[N 1],tot=1,d[N 1],cur[n1];

结构边{int to,nxt,cap } e[N * N * 4];

void add(int x,int y,int z){ 0

总收入.nxt=h[x],h[x]=tot,e[tot].to=y,e[tot].cap=z;

总收入.nxt=h[y],h[y]=tot,e[tot].to=x,e[tot].cap=0;

}

queueintq

bool bfs(){ 0

memset(d,0,sizeof(d));

d[s]=1,q . push(s);

while(!q . empty()){ 0

int x=q . front();q . pop();cur[x]=h[x];

for(int I=h[x];我;i=e[i]。nxt)if(e[i].船长!d[e[i].to])

d[e[i].to]=d[x] 1,q.push(e[i]).到);

}

返回d[t]1 : 0;

}

int dfs(int x,int flow){ 0

if(t==x)回流;

int res=flow

for(int I=cur[x];我;i=e[i]。nxt) if(e[i].cap d[x] 1==d[e[i].to](

int now=dfs(e[i]).to,min(res,e[i]).cap));

if(!现在d[e[I]].to]=0;

否则。现在,^ 1号cap=now,RES-=now;

if(!res)回流;

}

回流;

}

int main(){ 0

//int T=read();while(T-)solve();

n=read(),m=read();

代表(I,1,n){ 0

scanf("% s ",w1);

rep(j,1,m)a[I][j]=w[j]==' B ';

}

int ans=0;

rep(i,1,n)rep(j,1,m)ans=(u[I][j]=a[i][j]^ a[I 1][j]^ a[I][j 1]^ a[I 1][j 1]);

rep(i,1,n - 1)rep(j,1,m - 1)if(u[i][j])add(i,j n - 1,1);

s=n m - 1,t=S1;

rep(i,1,n - 1)if(u[i][m])add(s,I,1);

rep(i,1,m - 1)if(u[n][i])add(i n - 1,t,1);

int sum=0;

while(bfs())sum=dfs(s,n ^ m);

if(sum)printf('%d\n ',ans-sum((sum 1)^ u[n][m])-u[n][m]);

else printf('%d\n ',ans);

返回0;

}

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/74747.html

(0)

相关推荐

  • 削木为使,神农炎帝他教会了人们哪些东西

    技术削木为使,神农炎帝他教会了人们哪些东西一、制耒耜,种五谷,奠定了农工基础削木为使。耒耜的使用和种五谷,解决了民以食为天的大事,促进了农业生产的发展,为人类由原始游牧生活向农耕文明转化创造了条件。二、尝百草,开医药先河

    生活 2021年10月22日
  • 松柏读音,赠从弟其二刘桢这首古诗的读音

    技术松柏读音,赠从弟其二刘桢这首古诗的读音zèng cóng dì qí èr赠从弟·其二
    wèi liú zhēn
    魏晋松柏读音:刘桢
    tíng tíng shān shàng sōng,sè sè gǔ zhōng

    生活 2021年10月21日
  • 电脑安装安卓系统,安卓系统如何安装在电脑上

    技术电脑安装安卓系统,安卓系统如何安装在电脑上手机使用电脑下载安装软件的方法电脑安装安卓系统:
    1.使用电脑浏览器下载APK格式的安装包,连接数据线传输至手机,然后操作手机:在应用程序-我的文件中找到安装包,运行后点击安

    生活 2021年10月20日
  • bv电线规格,BV和BVR线的所有规格

    技术bv电线规格,BV和BVR线的所有规格1、BV、BVV、BVR电源线:简单嘀来说: vv在电线术语是指两层聚露乙烯意义bv电线规格; BV聚露乙烯绝缘铜芯线,独芯线; BVV,聚露乙烯护套铜芯线,两芯线; (图

    生活 2021年10月21日
  • dubbo泛化调用的原理(使用泛化方式调用dubbo)

    技术如何通过API方式使用dubbo泛化调用这篇文章主要介绍“如何通过API方式使用dubbo泛化调用”,在日常操作中,相信很多人在如何通过API方式使用dubbo泛化调用问题上存在疑惑,小编查阅了各式资料,整理出简单好

    攻略 2021年12月15日
  • mybatis-plus判断数据是否存在(springboot mybatisplus使用教程)

    技术spring boot+mybatis-plus怎样使用shardingsphere分库分表spring boot+mybatis-plus怎样使用shardingsphere分库分表,相信很多没有经验的人对此束手无

    攻略 2021年12月20日