CF679C(Bear and Square Grid) 经典好题
题目链接:传送门
题目大意:给你一个n*n包含".","X"的图,你有一次机会选择一个k*k的子矩阵,将子矩阵全部变为".",问当操作过后,得到的最大联通子块包含的"."的数目是多少。
题目思路:其实这个题自己只想到了一个暴力的思路,当然TLE没商量,但实际上正确的想法就是先dfs预处理所有"."的联通块,之后的想法技巧性太强了,
操作是模拟将子矩阵右移,直接暴力会TLE,而我们可以想到实际上移动的时候我们只需要删掉最左边的一列,加上最右边的一列就达到了移动的子矩阵的目的。
当然这个题既考验想法又考验码力,但是自己太弱,参考了很多别人的代码。。。努力!
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <stack>
#include <cctype>
#include <queue>
#include <string>
#include <vector>
#include <set>
#include <map>
#include <climits>
#define lson root<<1,l,mid
#define rson root<<1|1,mid+1,r
#define fi first
#define se second
#define ping(x,y) ((x-y)*(x-y))
#define mst(x,y) memset(x,y,sizeof(x))
#define mcp(x,y) memcpy(x,y,sizeof(y))
using namespace std;
#define gamma 0.5772156649015328606065120
#define MOD 1000000007
#define inf 0x3f3f3f3f
#define N 100005
#define maxn 20005
typedef pair<int,int> PII; int n,k,ans,all,cnt,temp;
char pic[][];
int vis[][];
int color[]; ///子块所含 "." 的数目
int sum[][]; ///二维前缀和,避免一个点重复计数
int vi[]; ///标记数组,记录联通块是否计数过 void dfs(int x,int y){
++temp;
vis[x][y]=cnt;
if(pic[x-][y]=='.'&&!vis[x-][y])dfs(x-,y);
if(pic[x+][y]=='.'&&!vis[x+][y])dfs(x+,y);
if(pic[x][y-]=='.'&&!vis[x][y-])dfs(x,y-);
if(pic[x][y+]=='.'&&!vis[x][y+])dfs(x,y+);
}
inline void del(int x,int y){ ///删点
if(!vis[x][y])return;
int t=vis[x][y];
--vi[t];
if(!vi[t])all-=color[t];
}
inline void ins(int x,int y){ ///加点
if(!vis[x][y])return;
int t=vis[x][y];
if(!vi[t])all+=color[t];
++vi[t];
}
inline int clac(int x,int y){
return sum[x+k-][y+k-]-sum[x+k-][y-]-sum[x-][y+k-]+sum[x-][y-];
}
int main(){
int i,j,group;
scanf("%d%d",&n,&k);
for(i=;i<=n;++i){
scanf("%s",pic[i]+);
for(j=;j<=n;++j){
sum[i][j]=sum[i-][j]+sum[i][j-]-sum[i-][j-];
if(pic[i][j]=='.')++sum[i][j];
} ///二维前缀和,新技能get
}
for(i=;i<=n;++i)for(j=;j<=n;++j)
if(pic[i][j]=='.'&&!vis[i][j]){
++cnt;
temp=;
dfs(i,j);
color[cnt]=temp;
}
for(i=;i<=n-k+;++i){
all=;mst(vi,);
for(j=i-;j<=k+i;++j){
for(int l=;l<=k;++l)
ins(j,l);
}
for(j=i;j<i+k;++j)ins(j,k+);
ans=max(ans,all+k*k-clac(i,));
for(j=;j<=n-k+;++j){
for(int l=i;l<i+k;++l){
del(l,j-);
ins(l,j+k);
}
del(i-,j-);del(i+k,j-);
ins(i-,j+k-);ins(i+k,j+k-);
ans=max(ans,all+k*k-clac(i,j));
}
}
printf("%d\n",ans);
return ;
}
CF679C(Bear and Square Grid) 经典好题的更多相关文章
- Codeforces Round #356 (Div. 1) C. Bear and Square Grid
		
C. Bear and Square Grid time limit per test 3 seconds memory limit per test 256 megabytes input stan ...
 - Codeforces 679C Bear and Square Grid
		
Bear and Square Grid 枚举k * k 的位置, 然后接上它周围白色连通块的数量, 再统计完全在k * k范围里的连通块, 这个只要某个连通块全部的方格 在k * k里面就好, 并且 ...
 - Codeforces Round #356 (Div. 2) E. Bear and Square Grid 滑块
		
E. Bear and Square Grid 题目连接: http://www.codeforces.com/contest/680/problem/E Description You have a ...
 - codeforces 680E  Bear and Square Grid  巧妙暴力
		
这个题是个想法题 先预处理连通块,然后需要用到一种巧妙暴力,即0变1,1变0,一列列添加删除 复杂度O(n^3) #include <cstdio> #include <iostre ...
 - Codeforces679C. Bear and Square Grid
		
n<=500,n*n的01矩阵,可以选择一个k*k的矩阵全变1,求最大1联通区域. 敢敢n^3..模拟k*k的矩阵的位置,从左到右扫的时候,每变一个位置只会引起边界的信息变化,就记含边界的k*k ...
 - 经典算法题每日演练——第十七题 Dijkstra算法
		
原文:经典算法题每日演练--第十七题 Dijkstra算法 或许在生活中,经常会碰到针对某一个问题,在众多的限制条件下,如何去寻找一个最优解?可能大家想到了很多诸如“线性规划”,“动态规划” 这些经典 ...
 - 经典算法题每日演练——第十六题 Kruskal算法
		
原文:经典算法题每日演练--第十六题 Kruskal算法 这篇我们看看第二种生成树的Kruskal算法,这个算法的魅力在于我们可以打一下算法和数据结构的组合拳,很有意思的. 一:思想 若存在M={0, ...
 - 经典算法题每日演练——第十四题 Prim算法
		
原文:经典算法题每日演练--第十四题 Prim算法 图论在数据结构中是非常有趣而复杂的,作为web码农的我,在实际开发中一直没有找到它的使用场景,不像树那样的频繁使用,不过还是准备 仔细的把图论全部过 ...
 - 经典算法题每日演练——第十一题 Bitmap算法
		
原文:经典算法题每日演练--第十一题 Bitmap算法 在所有具有性能优化的数据结构中,我想大家使用最多的就是hash表,是的,在具有定位查找上具有O(1)的常量时间,多么的简洁优美, 但是在特定的场 ...
 
随机推荐
- 使用Wifi连接ADB调试App
			
前提:你的手机ROOT过,做Android开发的,别跟人说你的手机不是ROOT的. 步骤: 1.在手机上把ADB服务进程的TCP端口设置为5555,这是Android ADB的默认调试商品.这需要 ...
 - .net core 控制台程序使用依赖注入(Autofac)
			
1.Autofac IOC 容器 ,便于在其他类获取注入的对象 using System; using System.Collections.Generic; using System.Linq; u ...
 - SSE,MSE,RMSE,R-square 指标讲解
			
SSE(和方差.误差平方和):The sum of squares due to error MSE(均方差.方差):Mean squared errorRMSE(均方根.标准差):Root mean ...
 - 使用intelliJ IDE开发java web项目
			
<!-- spring版本号 --> <spring.version>4.3.0.RELEASE</spring.version> <!-- mybatis版 ...
 - mysql启动与关闭
			
撰于:http://wenku.baidu.com/link?url=QV3mEJWnU4c8VZPjKGxz4A8gSmdjO2HZY7n963UaVx4l_uPKrh16tGxLyqjf5i3MA ...
 - C# 正则表达式替换制定关键词后面的所有内容
			
如题,将 {OUTSCIPTE} 关键词后的所有内容替换为string.Empty(包含关键字)这个正则该怎么写?我是 {OUTSCIPTE}(.*)$ 写的但是什么反应也没有 string str= ...
 - ios的设计原则
			
ios的设计原则 iOS设计的详细的主要宗旨例如以下: 1.易操作,所关心的主题清新 2.UI控件布局合理,图片质量清新 3.用户的使用习惯 4.字体的大小,主次分明 5.舒适的动画效果 在创建一个新 ...
 - redis命令_ZREM
			
ZREM key member [member ...] 移除有序集 key 中的一个或多个成员,不存在的成员将被忽略. 当 key 存在但不是有序集类型时,返回一个错误. 在 Redis 2.4 版 ...
 - redis命令_INCR
			
INCR key 将 key 中储存的数字值增一. 如果 key 不存在,那么 key 的值会先被初始化为 0 ,然后再执行 INCR 操作. 如果值包含错误的类型,或字符串类型的值不能表示为数字,那 ...
 - 新标准C++程序设计读书笔记_运算符重载
			
形式 返回值类型 operator 运算符(形参表) { …… } 运算符重载 (1)运算符重载的实质是函数重载(2)可以重载为普通函数,也可以重载为成员函数 class Complex { publ ...