题目链接:

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. Qt入门-layout布局

    开发一个图形界面应用程序,界面的布局影响到界面的美观.在设计一个界面之前,应该考虑到开发的界面可能给不用的用户使用,而用户的屏幕大小.纵横比例.分辨率可能不同,界面还可能是可缩放的,程序应该可以适应这 ...

  2. 深入理解Eureka - Eureka Client获取注册信息机制

    深入理解Eureka - Eureka Client获取注册信息机 Eureka Client提供了定时获取注册信息的机制.Eureka Client获取注册信息的所有逻辑都在DiscoveryCli ...

  3. 终端模拟工具:Xshell 4

    终端模拟工具:Xshell 4 2016-09-20 目录 1 安装 2 配置 3 命令 Xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Window ...

  4. git使用教程&&问题列表

    git教程[转] http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 git push ...

  5. PHP中Array的hash函数实现

    PHP中使用最多的非Array莫属了,那Array是如何实现的? 在PHP内部Array通过一个hashtable来实现,其中使用链接法解决hash冲突的问题,这样最坏情况下,查找Array元素的复杂 ...

  6. Zookeeper和分布式环境中的假死脑裂问题(转)

    Zookeeper和分布式环境中的假死脑裂问题 最近和同事聊天无意间发现他们的系统也存在脑裂的问题.想想当初在我们的系统中为了解决脑裂花了非常大的功夫,现在和大家一起讨论下脑裂,假死等等这些问题和解决 ...

  7. javascript总述

    一.JavaScript核心 一个完整的JavaScript应该由下列三个不同的部分组成. 1.核心(ECMAScript) 2.文档对象模型(DOM,Document Object Model) 3 ...

  8. file文件与base64字符串的相互转换

    今天心情不好,不想说话. /** * 文件转base64字符串 * @param file * @return */ public static String fileToBase64(File fi ...

  9. SparkR:数据科学家的新利器

    摘要:R是数据科学家中最流行的编程语言和环境之一,在Spark中加入对R的支持是社区中较受关注的话题.作为增强Spark对数据科学家群体吸引力的最新举措,最近发布的Spark 1.4版本在现有的Sca ...

  10. ggplot饼图

    目录: 原始图样 如何去除饼图中心的杂点 如何去除饼图旁边的标签 如何去掉左上角多出来的一横线 如何去掉图例的标题,并将图例放到上面 如何对图例的标签加上百分比 如何让饼图的小块按顺时针从大到小的顺序 ...