题目链接:

cid=2095&pid=7">csu1510

解题思路:

要求解四个值x_min,x_max,y_min,y_max

首先考虑x_min怎样得到:由于机器人最后有能够面向四个方向(E,W,N,S),我们能够用一个数组a[4]来存机器人面向4个方向时x的值

a[0]: x+,a[1]:x-。a[2]:y+,a[3],y-;

仅仅要求出a[4]最后比較出最小值,即为x_min

而求a[4]的关键在于运行?命令时怎样得到最优解:

a[x]=Min(左转,右转,前进);

即 a[0]=Min(a[2],a[3],a[0]+1);

同理得到a[1],a[2],a[3]

代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#define INF 9999
using namespace std;
char str[1050]; int Min(int a,int b,int c)
{
if(a>b)
a=b;
if(a>c)
a=c;
return a;
} int Max(int a,int b,int c)
{
if(a<b)
a=b;
if(a<c)
a=c;
return a;
} void change(int* t,int dir)
{
int tt=t[0];
if(dir)
{
t[0]=t[3];
t[3]=t[1];
t[1]=t[2];
t[2]=tt;
}
else
{
t[0]=t[2];
t[2]=t[1];
t[1]=t[3];
t[3]=tt;
}
} int main()
{
int len;
int t[4];
int Case=1;
while(~scanf("%s",str))
{
int a[4]= {0,-INF,-INF,-INF};
int b[4]= {0,INF,INF,INF};
int c[4]= {0,-INF,-INF,-INF};
int d[4]= {0,INF,INF,INF};
len=strlen(str);
for(int i=0; i<len; i++)
{
if(str[i]=='F')
{
a[0]++,a[1]--;
b[0]++,b[1]--;
c[2]++,c[3]--;
d[2]++,d[3]--;
}
else if(str[i]=='L')
{
change(a,1);
change(b,1);
change(c,1);
change(d,1);
}
else if(str[i]=='R')
{
change(a,0);
change(b,0);
change(c,0);
change(d,0);
}
else
{
t[0]=Max(a[0]+1,a[2],a[3]);
t[1]=Max(a[1]-1,a[2],a[3]);
t[2]=Max(a[0],a[1],a[2]);
t[3]=Max(a[0],a[1],a[3]);
memcpy(a,t,16);
t[0]=Min(b[0]+1,b[2],b[3]);
t[1]=Min(b[1]-1,b[2],b[3]);
t[2]=Min(b[0],b[1],b[2]);
t[3]=Min(b[0],b[1],b[3]);
memcpy(b,t,16);
t[0]=Max(c[0],c[2],c[3]);
t[1]=Max(c[1],c[2],c[3]);
t[2]=Max(c[0],c[1],c[2]+1);
t[3]=Max(c[0],c[1],c[3]-1);
memcpy(c,t,16);
t[0]=Min(d[0],d[2],d[3]);
t[1]=Min(d[1],d[2],d[3]);
t[2]=Min(d[0],d[1],d[2]+1);
t[3]=Min(d[0],d[1],d[3]-1);
memcpy(d,t,16);
}
}
t[0]=max(Max(a[0],a[1],a[2]),a[3]);
t[1]=min(Min(b[0],b[1],b[2]),b[3]);
t[2]=max(Max(c[0],c[1],c[2]),c[3]);
t[3]=min(Min(d[0],d[1],d[2]),d[3]);
printf("Case %d: %d %d %d %d\n",Case++,t[1],t[0],t[3],t[2]);
}
return 0;
}

csu1510 Happy Robot 递推的更多相关文章

  1. ZOJ 3981:Balloon Robot(思维+递推)

    题目链接 题意 有n支队在m个位置上做题,有一个机器人位置1到位置m再到位置1循环走派发气球,当队伍a在时间b做完了一道题目的时候,假如机器人走到队伍a的位置的时间为c,那么这个队伍的不开心值就是c- ...

  2. 【BZOJ-2476】战场的数目 矩阵乘法 + 递推

    2476: 战场的数目 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 58  Solved: 38[Submit][Status][Discuss] D ...

  3. 从一道NOI练习题说递推和递归

    一.递推: 所谓递推,简单理解就是推导数列的通项公式.先举一个简单的例子(另一个NOI练习题,但不是这次要解的问题): 楼梯有n(100 > n > 0)阶台阶,上楼时可以一步上1阶,也可 ...

  4. Flags-Ural1225简单递推

    Time limit: 1.0 second Memory limit: 64 MB On the Day of the Flag of Russia a shop-owner decided to ...

  5. 利用Cayley-Hamilton theorem 优化矩阵线性递推

    平时有关线性递推的题,很多都可以利用矩阵乘法来解决. 时间复杂度一般是O(K3logn)因此对矩阵的规模限制比较大. 下面介绍一种利用利用Cayley-Hamilton theorem加速矩阵乘法的方 ...

  6. 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】

    还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ...

  7. 简单递推 HDU-2108

    要成为一个ACMer,就是要不断学习,不断刷题...最近写了一些递推,发现递推规律还是挺明显的,最简单的斐波那契函数(爬楼梯问题),这个大家应该都会,看一点稍微进阶了一点的,不是简单的v[i] = v ...

  8. [ACM_动态规划] 数字三角形(数塔)_递推_记忆化搜索

    1.直接用递归函数计算状态转移方程,效率十分低下,可以考虑用递推方法,其实就是“正着推导,逆着计算” #include<iostream> #include<algorithm> ...

  9. 矩阵乘法&矩阵快速幂&矩阵快速幂解决线性递推式

    矩阵乘法,顾名思义矩阵与矩阵相乘, 两矩阵可相乘的前提:第一个矩阵的行与第二个矩阵的列相等 相乘原则: a b     *     A B   =   a*A+b*C  a*c+b*D c d     ...

随机推荐

  1. 如何保证RabbitMQ的消息不丢失及其背后的原理

    一.消息为什么丢失 RabbitMQ默认情况下的交换机和队列以及消息是非持久化的,也就是说在服务器重启或者宕机恢复后,之前创建的交换机和队列都将不复存在,之前未消费的消息也就消失不见了.原因在于每个队 ...

  2. VC++编程之道读书笔记

    第二篇 缪误21:位图数据是按照红绿蓝顺序存储的 大家都知道位图的颜色是由红.绿.蓝三个分量构成的,但是位图颜色数据存储的方式则不是按照这个顺序存储的,而是按照蓝.绿.红的顺序存储的.并且对于真彩色位 ...

  3. JAVA中的protected(详解),以及和clone()方法有关的一些问题

    http://blog.csdn.net/ciawow/article/details/8262609 ************************************************ ...

  4. SharePoint自动化系列——Upload files to SharePoint library using PowerShell.

    转载请注明出自天外归云的博客园:http://www.cnblogs.com/LanTianYou/ 日常的SharePoint站点测试中,我们经常要做各种各样的数据,今天又写了几个脚本,发现自己写的 ...

  5. Python实现二叉树及其4种遍历

    Python & BinaryTree 1. BinaryTree (二叉树) 二叉树是有限个元素的集合,该集合或者为空.或者有一个称为根节点(root)的元素及两个互不相交的.分别被称为左子 ...

  6. 纯css3简单实用的checkbox复选框和radio单选框

    昨天为大家分享了一款很炫的checkbox复选框和radio单选框,今天再给大家带来一款简单实用的checkbox复选框和radio单选框.界面清淅.舒服.先给大家来张效果图: 在线预览   源码下载 ...

  7. javascript 常用对象

    <!doctype html> <head> <script type="text/javascript"> /* ps:需要注意的是部分的方法 ...

  8. 【C#】事件(Event)和代理/委托(Delegate)

    代理(Delegate)的例子 delegate void MyDelegate(string str,int index); // 声明代理 class Test { public static v ...

  9. 专题实验 EXP & IMP

    导入导出时 oracle 提供的实用工具, 如果这些被导出的对象还存在其他的相关对象, 比如要被导出的表上还存在索引, 注释等, 则导出工具会自动将这些相关的对象也提取出来, 并放入到导出的文件中去. ...

  10. jQuery EasyUI教程之datagrid应用-2

    二.DataGrid的扩展应用 上一份教程我们创建的一个CRUD应用是使用对话框组件来增加或编辑用户信息.本教程将教你如何创建一个CRUD 数据表格(datagrid). 为了让这些CRUD功能正常工 ...