博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[51Nod1487]占领资源
阅读量:6264 次
发布时间:2019-06-22

本文共 1444 字,大约阅读时间需要 4 分钟。

题目大意:

​  有一个$n\times m(x,m\leq 100)$的网格图,每个格子有一个权值$w_{i,j}(1\leq w_{i,j}\leq 9)$。你可以在图中选两个格子,每个格子$(x,y)$可以接收$k(k\leq 10)$个格子,$(x+dx[1],y+dy[1]),(x+dx[2],y+dy[2]),\ldots,(x+dx[k],y+dy[k])$的权值。超出边界的能量不接收,每个格子的权值最多被接收一次,问最多能接收多少权值。

思路:

​  考虑选择不同格子,吸收权值的范围不相交的情况,我们可以直接暴力$O(nmk)$求出每个点能吸收的权值,然后选两个最大的加起来即可。
​  现在每个格子的吸收范围可能会相交,因此我们还需要分两种情况考虑。
  我们可以先求出每个点能吸收的权值,然后找出吸收范围会和该点重合的点,不难发现这样的点最多只有$k^2$个。
  对于会相交的点,我们暴力求一下可以吸收哪些点的权值,对于不相交的点,可以直接用稀疏表求区间最大值,时间复杂度$O(nmk^2\log(nm))$。

1 #include
2 #include
3 #include
4 #include
5 inline int getint() { 6 register char ch; 7 register bool neg=false; 8 while(!isdigit(ch=getchar())) if(ch=='-') neg=true; 9 register int x=ch^'0'; 10 while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0'); 11 return neg?-x:x; 12 } 13 inline int getblock() { 14 register char ch; 15 while(!isdigit(ch=getchar())); 16 return ch^'0'; 17 } 18 typedef std::pair
Point; 19 const int N=100,K=10,logN2=15; 20 std::set
set; 21 bool vis[N*N],b[N][N]; 22 int n,m,k,a[N][N],dx[K],dy[K],max[N*N][logN2],q[K*K+3]; 23 inline bool check(const int &x,const int &y) { 24 return x>=0&&x
=0&&y
>23&255)-127; 31 } 32 inline int query(const int &l,const int &r) { 33 const int k=log2(r-l+1); 34 return std::max(max[l][k],max[r-(1<

 

转载于:https://www.cnblogs.com/skylee03/p/8260271.html

你可能感兴趣的文章
Android ROM开发--ubuntu下编译CyanogenMod生成SDK
查看>>
Cocos2d下TexturePacker2.3版会给iphone, ipad通用版带来的问题
查看>>
全新的互动广告牌,待遇男女有别
查看>>
Language modeling meets inference networks
查看>>
mvc3学习之--安装
查看>>
Html5 学习系列(一)认识HTML5
查看>>
弗洛伊德算法
查看>>
((ios开发学习笔记 十))代码实现自定义TableView
查看>>
WPF 之转换器
查看>>
mongo-update 操作(2)
查看>>
添加列前先检查
查看>>
[Step By Step]SAP HANA PAL KNN 近邻预测分析K- Nearest Neighbor编程实例KNN
查看>>
oracle set命令详解
查看>>
可变的数据变量一定要初始化之后才能再用
查看>>
浅用block 转
查看>>
HDU 3032 Nim or not Nim?(博弈,SG打表找规律)
查看>>
Android soundpool初探
查看>>
c#操作access,update语句不执行的解决办法
查看>>
艺术(良质)的代价--读禅与摩托车维修艺术
查看>>
Linux 比较重要且难掌握命令 集合
查看>>