惯例,化简题意(看长短决定难度)

一块草坪上有两种点(姑且称为a和b),各有坐标,现在能同时使所有a点向东西南北任意一个方向移动一个单位,若a点与b点重合,则答案增加重合数,求答案的最大值并且求出这个命令序列

solution&&thinking

首先,dp无疑(不能贪,随后hack系列。)

其次,方程式巨好推是不是

f[i][j][k]表示第i步,向东共走了j,北共走了k的最大值,四个转移,之后比较最值,加上预处理的数量,最多是绿的难度。

那么,第二问就是这题变成蓝色的原因。

要求序列!还要字典序最小。

按着yzy的讲法,让每个点同时移动,求序列,但是好像不太可行

考虑求出最优解之后,从最优解开始dfs,减去状态,试着还原一下原状态,强行枚举出序列(又是一个dp233)

既然这又是一个dp,那就又可以迭代写了?好呀好呀....

先枚举E(向东)之后依次枚举方向,一旦找到一个之前的状态能加上预处理出来的数量能够达到当前状态(其实这里就是在模拟dfs),就输出这个字符。

然后...然后就没有了

坑点:

这里必须要骂一下出题人,简直没有良心。真的是映射了zym大佬的一句话

用心出题,用脚造数据

说好的大于0呢?说好的小于1000呢?

被狗吃了吗?

还要防负???

wtf.......

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=;
const int T=;
const int dx[]={,,,-};
const int dy[]={,,-,};
const int dd[]={,,,};
int n,m,K;
int a[maxn],b[maxn],c[maxn],d[maxn];
int f[T<<][T<<][T<<];
int g[T<<][T<<];
int main()
{
scanf("%d%d%d",&n,&m,&K);
for(int i=;i<=n;i++)
{
scanf("%d%d",&a[i],&b[i]);
}
for(int i=;i<=m;i++)
{
scanf("%d%d",&c[i],&d[i]);
}
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
if(abs(c[j]-a[i])+abs(d[j]-b[i])<=K)
g[c[j]-a[i]+T][d[j]-b[i]+T]++;
}
}
for(int i=K;i>=;i--)
{
for(int j=T-i;j<=T+i;j++)
{
for(int k=T-i;k<=T+i;k++)
{
for(int l=;l<;l++)
{
f[i][j][k]=max(f[i+][j+dx[l]][k+dy[l]],f[i][j][k]);
}
f[i][j][k]+=g[j][k];
}
}
}
printf("%d\n",f[][T][T]);
int u=T,v=T,j;
for(int i=;i<K;i++)
{
for(j=;j<;j++)
if(f[i][u][v]==f[i+][u+dx[j]][v+dy[j]]+g[u][v])
break;
u+=dx[j];
v+=dy[j];
printf("%c",dd[j]);
}
return ;
}

(完)

P2905 [USACO08OPEN]农场危机Crisis on the Farm(简单dp+麻烦“回溯”)的更多相关文章

  1. bzoj1605 / P2905 [USACO08OPEN]农场危机Crisis on the Farm

    P2905 [USACO08OPEN]农场危机Crisis on the Farm 发现总步数$k<=30$,考虑用$k$瞎搞 设$f[u][i][j]$表示已经吹$u$次哨,全体奶牛向右走$i ...

  2. 洛谷P2905 [USACO08OPEN]农场危机Crisis on the Farm

    P2905 [USACO08OPEN]农场危机Crisis on the Farm 题目描述 约翰和他的奶牛组建了一只乐队“后街奶牛”,现在他们正在牧场里排练.奶牛们分成一堆 一堆,共1000)堆.每 ...

  3. P2905 [USACO08OPEN]农场危机Crisis on the Farm

    传送门 DP 设 f [ i ] [ j ] [ k ] 表示已经走了 i 步,向上走了 j 步,向右走了 k 步时能拯救的最多奶牛数(j,k可以为负,表示反向) 设 g [ i ] [ j ] 表示 ...

  4. 洛谷 P2905 [USACO08OPEN]农场危机Crisis on the Farm

    题目描述 约翰和他的奶牛组建了一只乐队“后街奶牛”,现在他们正在牧场里排练.奶牛们分成一堆 一堆,共1000)堆.每一堆里,30只奶牛一只踩在另一只的背上,叠成一座牛塔.牧场 里还有M(1 < ...

  5. bzoj1621 / P2907 [USACO08OPEN]农场周围的道路Roads Around The Farm

    P2907 [USACO08OPEN]农场周围的道路Roads Around The Farm 基础dfs,按题意递归即可. #include<iostream> #include< ...

  6. [USACO08OPEN]农场周围的道路Roads Around The Farm BZOJ 1621 DFS

    Farmer John's cows have taken an interest in exploring the territory around the farm. Initially, all ...

  7. BZOJ1605 [Usaco2008 Open]Crisis on the Farm 牧场危机

    标题好长&&我是权限狗,汪汪! 题没看懂的我以为这是一道极难滴题目...然后,然后我就看懂题了. 数据少给了一个条件K <= 30...(没这条件还做个鬼...) f[k, i, ...

  8. BZOJ 1605 [Usaco2008 Open]Crisis on the Farm 牧场危机:dp【找转移路径】

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1605 题意: 平面直角坐标系中,有n个点,m个标记(坐标范围1~1000). 你可以发出口 ...

  9. BZOJ 1605 [Usaco2008 Open]Crisis on the Farm 牧场危机 DP

    题意:链接 方法: DP 解析: 第一眼搜索题,复杂度不同意dfs,并且牛的数量太多不能bfs,迭代更不可能,A*不会估价.可能记忆化? 等等记忆化我还搜个毛线- 直接改成DP就好了. 状态非常好想非 ...

随机推荐

  1. 小程序webview跳转页面后没有返回按钮完美解决方案

    随着小程序越来越火爆,使一个产品如果只有公众号H5页面和APP显得不怎么完美,总感觉不搭上小程序这趟流量车,就会少了点什么,心里别扭地很.在此驱动下,我所在公司也决定赶紧上车. 但是,如果要按照小程序 ...

  2. Color Length UVALive - 5841

    题文:见网页:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=sho ...

  3. 解决:Specifying a namespace in include() without providing an app_name和XXX is not a registered namespace问题

    python3 Django 环境下,如果你遇到namespace没有注册以及在根目录下urls.py中的include方法的第二个参数namespace添加之后就出错的问题. 出错问题: 'Spec ...

  4. Uber Go 语言编程规范

    目录 Uber Go 语言编程规范 1. 介绍 2. 编程指南 3. 性能相关 4. 编程风格 5. 编程模式(Patterns) 6. 总结 Uber Go 语言编程规范 相信很多人前两天都看到 U ...

  5. CF401D Roman and Numbers 状压DP

    CF401D 题意翻译 将n(n<=10^18)的各位数字重新排列(不允许有前导零) 求 可以构造几个mod m等于0的数字 题目描述 Roman is a young mathematicia ...

  6. TestLink+Jenkins在Ubuntu16.04搭建集成测试环境

    序章 序1:TestLink和TestLink-API-Python-client 目前TestLink的最新版本是1.9.19 TestLink-API-Python-client支持的TestLi ...

  7. 详细解读 Spring AOP 面向切面编程(一)

    又是一个周末, 今天我要和大家分享的是 AOP(Aspect-Oriented Programming)这个东西,名字与 OOP 仅差一个字母,其实它是对 OOP 编程方式的一种补充,并非是取而代之. ...

  8. IaaS基础平台

    第一部分:IaaS云计算基础架构平台 服务器:先电 任务一.IaaS云平台搭建 基础环境: 1.使用命令行方式设置主机名,防火墙以及 SELinux 设置如下: (1)设置控制节点主机名 contro ...

  9. HTML5+WebGL 的加油站 3D 可视化监控

    前言 随着数字化,工业互联网,物联网的发展,我国加油站正向有人值守,无人操作,远程控制的方向发展,传统的人工巡查方式逐渐转变为以自动化控制为主的在线监控方式,即采用数据采集与监控系统 SCADA.SC ...

  10. 基准测试了 ArrayList 和 LinkedList ,发现我们一直用 ArrayList 也是没什么问题的

    ArrayList 应该是 Java 中最常用的集合类型了,以至于我们说到集合就会自然而然的想到 ArrayList.很多同学都没有用过除了 ArrayList 之外的其他集合,甚至于都已经忘了除了 ...