AGC004E - Salvage Robots(dp,思维)

AGC004E - Salvage Robots

Solution

怎么又双叒叕遇到和NOIP2020T4NOIP2020T4NOIP2020T4和那道CFCFCF题一样的题了啊,惨痛回忆QAQQAQQAQ

大概就是把问题看成刚开始的点不动,整个网格图动,机器人向上111格等于网格整体向下111格,左右同理。如果网格某一时刻有一部分在边界外面,就把那些部分切掉,然后把所有经过原点(EEE所在的点)的机器人都收集起来。

因此倘若我们向上、下、左、右分别移动了最多u,d,l,ru,d,l,ru,d,l,r格,那么现在的网格就是[d+1...n−u,r+1...m−l][d+1...n-u,r+1...m-l][d+1...nu,r+1...ml]范围内的,然后我们可以选择一个边界位置扩展出去,假设u+1u+1u+1,那么假设移动到了位置(u+1,y),y∈[l,r](u+1,y),y\in[l,r](u+1,y),y[l,r],显然对于所有y∈[max(r+1,l),min(m−l,r)]y\in [max(r+1,l),min(m-l,r)]y[max(r+1,l),min(ml,r)],位置(u+1,y)(u+1,y)(u+1,y)上的机器人都可以被收集而不影响边界大小。这里要对边界取max/minmax/minmax/min是因为边界外的机器人都超出过边界消失了。

于是我们有了一个dpdpdp的思路:令fu,d,l,rf_{u,d,l,r}fu,d,l,r表示向上、下、左、右分别移动了最多u,d,l,ru,d,l,ru,d,l,r格最多收集的机器人。

每次可以从边界往外扩展一格,然后把那个边界上的机器人都加到新的状态里。预处理横纵方向的机器人个数前缀和即可O(1)O(1)O(1)转移。

时间复杂度O(n4)O(n^4)O(n4),空间也是O(n4)O(n^4)O(n4),空间256MB256MB256MB,只能开shortshortshort

Code

#include <vector>
#include <list>
#include <map>
#include <set>
#include <deque>
#include <queue>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cctype>
#include <string>
#include <cstring>
#include <ctime>
#include <cassert>
#include <string.h>
//#include <unordered_set>
//#include <unordered_map>
//#include <bits/stdc++.h>#define MP(A,B) make_pair(A,B)
#define PB(A) push_back(A)
#define SIZE(A) ((int)A.size())
#define LEN(A) ((int)A.length())
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define fi first
#define se secondusing namespace std;template<typename T>inline bool upmin(T &x,T y) { return y<x?x=y,1:0; }
template<typename T>inline bool upmax(T &x,T y) { return x<y?x=y,1:0; }typedef long long ll;
typedef unsigned long long ull;
typedef long double lod;
typedef pair<int,int> PR;
typedef vector<int> VI;const lod eps=1e-11;
const lod pi=acos(-1);
const int oo=1<<30;
const ll loo=1ll<<62;
const int mods=1e9+7;
const int MAXN=101;
const int INF=0x3f3f3f3f;//1061109567
/*--------------------------------------------------------------------*/
inline int read()
{int f=1,x=0; char c=getchar();while (c<'0'||c>'9') { if (c=='-') f=-1; c=getchar(); }while (c>='0'&&c<='9') { x=(x<<3)+(x<<1)+(c^48); c=getchar(); }return x*f;
}
int X,Y;
char st[MAXN];
short f[MAXN][MAXN][MAXN][MAXN],sl[MAXN][MAXN],su[MAXN][MAXN];
signed main()
{int n=read(),m=read();for (int i=1;i<=n;i++){scanf("%s",st+1);for (int j=1;j<=m;j++) {if (st[j]=='E') X=i,Y=j;if (st[j]=='o') sl[i][j]=su[i][j]=1;}}for (int i=1;i<=n;i++)for (int j=1;j<=m;j++) sl[i][j]+=sl[i][j-1],su[i][j]+=su[i-1][j];for (int u=0;u<X;u++)for (int d=0;d<=n-X;d++)for (int l=0;l<Y;l++)for (int r=0;r<=m-Y;r++) f[u][d][l][r]=-n*m;f[0][0][0][0]=0;short mx=0;for (int u=0;u<X;u++)for (int d=0;d<=n-X;d++)for (int l=0;l<Y;l++)for (int r=0;r<=m-Y;r++){if (X-(u+1)>=d+1) upmax(f[u+1][d][l][r],(short)(f[u][d][l][r]+sl[X-(u+1)][min(Y+r,m-l)]-sl[X-(u+1)][max(Y-l-1,r)]));if (X+(d+1)<=n-u) upmax(f[u][d+1][l][r],(short)(f[u][d][l][r]+sl[X+(d+1)][min(Y+r,m-l)]-sl[X+(d+1)][max(Y-l-1,r)]));if (Y-(l+1)>=r+1) upmax(f[u][d][l+1][r],(short)(f[u][d][l][r]+su[min(X+d,n-u)][Y-(l+1)]-su[max(X-u-1,d)][Y-(l+1)]));if (Y+(r+1)<=m-l) upmax(f[u][d][l][r+1],(short)(f[u][d][l][r]+su[min(X+d,n-u)][Y+(r+1)]-su[max(X-u-1,d)][Y+(r+1)]));upmax(mx,f[u][d][l][r]);}printf("%d\n",(int)mx);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315568.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL Server 2012如何打开2016的profiler文件

作者&#xff1a;markjiang7m2原文地址&#xff1a;https://www.cnblogs.com/markjiang7m2/p/10980191.html背景在上星期&#xff0c;公司负责support的同事接到反馈说某个项目生产环境上的某个页面加载很慢&#xff0c;一般遇到这种问题&#xff0c;我们的support同事都会先上…

Codeforces Round #655 (Div. 2) E. Omkar and Last Floor 区间dp + 巧妙的状态设计

传送门 题意&#xff1a; 思路&#xff1a; 按照贪心的思路来考虑的话&#xff0c;显然是每一列111的个数越多越好&#xff0c;所以我们能放到一列就放到一列。设f[l][r]f[l][r]f[l][r]为在[l,r][l,r][l,r]内&#xff0c;区间全部都在里面的贡献。显然这个贡献就是全部落在[l…

AKS使用Azure File实现动态持久化存储

本文作者|搪瓷小娃娃本文来源|搪瓷小娃娃博客园如我们所知&#xff0c;Kubernetes通过 Volume 为集群中的容器提供存储&#xff0c;通过Persistent Volume 和 Persistent Volume Claim实现Volume 的静态供给和动态供给。Azure File和Azure Disk 也在Kubernetes 支持的动态供给 …

AGC005D - ~K Perm Counting(组合数学,背包,dp)

AGC005D - ~K Perm Counting Solution 经典数排列个数题&#xff0c;写了个大麻烦容斥。 直接容斥&#xff0c;考虑求出fif_ifi​表示有iii个位置∣pi−i∣k|p_i-i|k∣pi​−i∣k的方案数。一个位置iii满足∣pi−i∣k|p_i-i|k∣pi​−i∣k&#xff0c;要么piikp_iikpi​ik&a…

Codeforces Round #704 (Div. 2) D. Genius‘s Gambit 构造 + 细节

传送门 题意&#xff1a; 给a,b,ka,b,ka,b,k&#xff0c;要求用aaa个000和bbb个111组成二进制xxx和yyy&#xff0c;并且x−yx-yx−y恰好有kkk个111&#xff0c;并且xxx和yyy不含前导零。 思路&#xff1a; 首先需要看到不含前导零&#xff0c;一开始没看见wa5了。让后一个很明…

ASP.NET Core 应用程序状态

在ASP.NET Core中&#xff0c;由多种途径可以对应用程序状态进行管理&#xff0c;使用哪种途径&#xff0c;由检索状态的时机和方式决定。应用程序状态指的是用于描述当前状况的任意数据。包括全局和用户特有的数据。开发人员可以根据不同的因素来选择不同的方式存储状态数据&a…

HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge(Set,线段树)

HDU6218 2017ACM/ICPC亚洲区沈阳站 Bridge Solution 我们考虑维护在环上的边的个数&#xff0c;答案就是总边数减去环上边数。 环的形态是这样的&#xff1a;(0,l),(0,l1)...(0,r),(1,r),(1,r−1)...(1,l)(0,l),(0,l1)...(0,r),(1,r),(1,r-1)...(1,l)(0,l),(0,l1)...(0,r),(…

Codeforces Round #704 (Div. 2) E. Almost Fault-Tolerant Database 思维

传送门 题意&#xff1a; 给nnn个长度为mmm的数组&#xff0c;要求构造一个长度为mmm的数组&#xff0c;使得这个数组与前面nnn个数组同一位置最多两个元素不同。 思路&#xff1a; 我们为了方便构造&#xff0c;可以先把要构造的数组看成nnn个数组的第一个数组&#xff0c;让…

Asp.net core使用MediatR进程内发布/订阅

1、背景最近&#xff0c;一个工作了一个月的同事离职了&#xff0c;所做的东西怼了过来。一看代码&#xff0c;惨不忍睹&#xff0c;一个方法六七百行&#xff0c;啥也不说了吧&#xff0c;实在没法儿说。介绍下业务场景吧&#xff0c;一个公共操作A&#xff0c;业务中各个地方…

[APIO2018] New Home 新家(线段树,二分答案,离散化)

[APIO2018] New Home 新家 Solution 对于时间轴我们直接离散化扫描线&#xff0c;维护每一个商店的加入和删除。 对于询问(x,t)(x,t)(x,t)&#xff0c;不好直接回答&#xff0c;这里的关键一步是&#xff1a;我们要求的是kkk种商店最小距离的最大值&#xff0c;于是考虑二分…

Codeforces Round #701 (Div. 2) C. Floor and Mod 数学分块

传送门 题意&#xff1a; 给两个数x,yx,yx,y。现在你计算有多少对a(a<x)a(a<x)a(a<x)和b(b<y)b(b<y)b(b<y)使得⌊ab⌋amodb\left \lfloor \frac{a}{b} \right \rfloora\bmod b⌊ba​⌋amodb。 思路&#xff1a; 因为xxx和yyy都是1e91e91e9的范围&#xff0…

AGC011D - Half Reflector(模拟)

AGC011D - Half Reflector Solution 先考虑改变一次。 我们令LLL表示往左走的球&#xff0c;RRR表示往右走的球&#xff0c;xxx表示任意种类的球&#xff0c;(−x)(-x)(−x)表示与xxx相反种类的球。 当球处于ARAARAARA的状态&#xff08;即有一个向右的球在两个AAA机器人之间…

[开源] FreeSql.Tools Razor 生成器

FreeSql 经过半年的开发和坚持维护&#xff0c;在 0.6.x 版本中完成了几大重要事件&#xff1a;1、按小包拆分&#xff0c;每个数据库实现为单独 dll&#xff1b;2、实现 .net framework 4.5 支持&#xff1b;3、同时支持 MySql.Data、MySqlConnector 的实现&#xff1b;4、自定…

Codeforces Round #701 (Div. 2) D. Multiples and Power Differences 思维构造

传送门 题意&#xff1a; 给定一个矩阵aaa&#xff0c;让你构造一个矩阵bbb&#xff0c;要求矩阵bbb的每个元素是aaa对应位置元素的倍数&#xff0c;且矩阵bbb的每两个相邻元素相差为k4(k>1)k^4(k>1)k4(k>1)。注意aaa的元素范围是1<a<161<a<161<a<…

AGC012D - Colorful Balls(并查集)

AGC012D - Colorful Balls Solution 连边题。 找出www最小的球yyy和www最小且颜色和yyy不同的球zzz。 yyy向所有colt̸coly,wtwy≤Ycol_t\not col_y,w_tw_y\leq Ycolt​​coly​,wt​wy​≤Y的球ttt连边。zzz向所有colt̸coly,wtwz≤Ycol_t\not col_y,w_tw_z\leq Ycolt​…

WebAssembly和Blazor:解决了一个存在十年的老问题

本文要点WebAssembly 是一种新的客户端技术&#xff0c;可以在所有现代浏览器&#xff08;包括移动浏览器&#xff09;中实现近乎原生的性能&#xff0c;而且不需要插件。许多语言&#xff0c;包括 C、C#、Go 和 Rust&#xff0c;都可以编译成面向基于栈的 WebAssembly 虚拟机的…

Educational Codeforces Round 103 (Rated for Div. 2) D. Journey dp

传送门 题意&#xff1a; 给n1n1n1个点&#xff0c;每两个点之间有一个字符L(表示i1连向i)L(表示i1连向i)L(表示i1连向i)或者R(表示i连向i1)R(表示i连向i1)R(表示i连向i1)&#xff0c;每秒可以移动一次&#xff0c;每移动一次每两个点之间的方向会互换&#xff0c;问每个点能到…

LG P4074 [WC2013] 糖果公园(带修莫队,树上莫队)

LG P4074 [WC2013] 糖果公园 Solution 树上带修莫队&#xff0c;主要还是复习带修莫队和树上莫队。 带修莫队&#xff1a; 带修莫队要先对lll分块的序号作为第一关键字&#xff0c;对rrr分块的序号作为第二关键字&#xff0c;时间ttt作为第三关键字排序&#xff0c;然后正常…

《电商后台系统产品逻辑解析》学习笔记

文是我阅读《电商产品经理宝典&#xff1a;电商后台系统产品逻辑全解析》一书的学习笔记&#xff0c;为后续我司做家居电商后台系统储备相关领域的业务知识。一、支撑线后台概览“前端用户的一小步&#xff0c;后台系统的一大步”&#xff0c;平时常见的功能如购物车、优惠券等…

P3403 跳楼机 同余最短路

传送门 题意&#xff1a; 思路&#xff1a; 转换一下题目就是用若干x,y,zx,y,zx,y,z能凑出来多少个<h<h<h的数。先考虑两个数y,zy,zy,z的情况&#xff0c;我们如果能求出来这两个数能凑出来的数设为sumsumsum&#xff0c;让后sumkx<hsumkx<hsumkx<h求出来…