HDU4452Running Rabbits(模拟)

pid=4452" target="_blank" style="">题目链接

题目大意:给N∗N的格子,然后有两仅仅兔子分别在(1,1)和(N,
N)上。如今给这两仅仅兔子一个出发方向,和每秒跳跃格子数和每过t秒方向就向左转这些条件。

假设这仅仅兔子跳到一定的步数碰到了墙壁。没法往那个方向跳了,那么就回头继续将剩余的步数跳完(这一点我之前没理解。

。弄了半天)。

假设两仅仅兔子在k点的时候在同个一个位置上。那么这两仅仅兔子就互换方向,这时候假设正好须要向左转。就不须要向左转。

解题思路:模拟,就是须要弄清除题意。先跳再换方向。假设碰到一起的话那么就不须要换方向了,还有碰到墙壁的时候的情况也要考虑清楚。

代码:

#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std; int N, T;
const int dir[4][2] = {{-1, 0}, {0, -1}, {1, 0}, {0, 1}}; struct Rabbit {
int d, s, t;
int x, y;
}r[2]; int change (char ch) { if (ch == 'N')
return 0;
else if (ch == 'W')
return 1;
else if (ch == 'S')
return 2;
else
return 3;
} void jumpe (int i) { int nx = r[i].x + r[i].s * dir[r[i].d][0];
int ny = r[i].y + r[i].s * dir[r[i].d][1]; if (nx > 0 && nx <= N && ny > 0 && ny <= N) {
r[i].x = nx;
r[i].y = ny;
} else { if (r[i].d == 0)
r[i].x += r[i].s - 2 * (r[i].x - 1);
else if (r[i].d == 1)
r[i].y += r[i].s - 2 * (r[i].y - 1);
else if (r[i].d == 2)
r[i].x -= r[i].s - 2 * (N - r[i].x);
else
r[i].y -= r[i].s - 2 * (N - r[i].y); r[i].d = (r[i].d + 2) % 4;
}
} int main () { char str[10];
while (scanf ("%d", &N) && N ) { scanf ("%s%d%d", str, &r[0].s, &r[0].t);
r[0].d = change(str[0]);
scanf ("%s%d%d", str, &r[1].s, &r[1].t);
r[1].d = change(str[0]);
r[0].x = r[0].y = 1;
r[1].x = r[1].y = N;
scanf ("%d", &T); for (int i = 1; i <= T; i++) { jumpe(0);
jumpe(1); // printf ("%d %d\n%d %d\n", r[0].x, r[0].y, r[1].x, r[1].y);
if (r[0].x == r[1].x && r[0].y == r[1].y)
swap(r[0].d, r[1].d);
else {
if ((i % r[0].t == 0))
r[0].d = (r[0].d + 1) % 4;
if ((i % r[1].t == 0))
r[1].d = (r[1].d + 1) % 4;
} } printf ("%d %d\n%d %d\n", r[0].x, r[0].y, r[1].x, r[1].y);
}
return 0;
}

HDU4452Running Rabbits(模拟)的更多相关文章

  1. hdu-4452-Running Rabbits

    /* Running Rabbits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...

  2. hdu 4452 Running Rabbits 模拟

    Running RabbitsTime Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. 模拟 HDOJ 4552 Running Rabbits

    题目传送门 /* 模拟:看懂题意,主要是碰壁后的转向,笔误2次 */ #include <cstdio> #include <algorithm> #include <c ...

  4. HDU 4452 Running Rabbits (模拟题)

    题意: 有两只兔子,一只在左上角,一只在右上角,两只兔子有自己的移动速度(每小时),和初始移动方向. 现在有3种可能让他们转向:撞墙:移动过程中撞墙,掉头走未完成的路. 相碰: 两只兔子在K点整(即处 ...

  5. 【HDU 4452 Running Rabbits】简单模拟

    两只兔子Tom和Jerry在一个n*n的格子区域跑,分别起始于(1,1)和(n,n),有各自的速度speed(格/小时).初始方向dir(E.N.W.S)和左转周期turn(小时/次). 各自每小时往 ...

  6. [模拟] hdu 4452 Running Rabbits

    意甲冠军: 两个人在一个人(1,1),一个人(N,N) 要人人搬家每秒的速度v.而一个s代表移动s左转方向秒 特别值得注意的是假设壁,反弹.改变方向 例如,在(1,1),采取的一个步骤,以左(1,0) ...

  7. 省选模拟赛 LYK loves rabbits(rabbits)

    题目描述 LYK喜欢兔子,它在家中养了3只兔子. 有一天,兔子不堪寂寞玩起了游戏,3只兔子排成一排,分别站在a,b,c这3个位置. 游戏的规则是这样的,重复以下步骤k次:选择两个不同的兔子A和B,假如 ...

  8. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  9. 故障重现, JAVA进程内存不够时突然挂掉模拟

    背景,服务器上的一个JAVA服务进程突然挂掉,查看产生了崩溃日志,如下: # Set larger code cache with -XX:ReservedCodeCacheSize= # This ...

随机推荐

  1. Solr4.7缓存技术

    磁盘IO往往是计算机系统响应速度的一个突出瓶颈,搜索引擎查询很平凡,减少搜索过程中的磁盘IO对提升搜索响应速度无疑有莫大的帮助,在solr中,提供自带的缓存机制.我们只需要在solrconfig.xm ...

  2. 利用cmake来搭建开发环境

    对于经常在终端下写程序的non-windows程序员,Makefile绝对是最常用的工具,小到一个文件的简单的测试程序,大到数百个文件的商业软件,只需要有shell,一个make命令就可得到可运行的程 ...

  3. winform之2---messagebox用法

    MessageBox.Show();可谓是winform开发中用的次数最多的东东啦.先贴一张msdn的图解 msdn好像没有更新哎,只提供了这几种方法,并且参数名称和最新的有差别,但实际上messag ...

  4. 一天一个类--ArrayList之一

    今天开始打算将JDK7种的一些类的源码分析一下,笔者认为了解源码就是了解其实现过程,这是非常重要的,而不是简单的记住方法的使用,关键是了解其思想和目的这才是重要的.所以笔者决定首先将从一些容器下手.[ ...

  5. 玩转Windows服务系列汇总(9篇文章)

    玩转Windows服务系列汇总 创建Windows服务Debug.Release版本的注册和卸载及其原理无COM接口Windows服务启动失败原因及解决方案服务运行.停止流程浅析Windows服务小技 ...

  6. Wince下实现ImageButton

    我们在winform中给按钮设置个背景图片超级简单,是不?可是在wince下面就没那么简单了,下面我来介绍一种方式来实现ImageButton. 实现思路是重新写一个usercontrol就ok.具体 ...

  7. 疯狂JAVA讲义第三章之数组篇

    package test;   /** * Desription: * @author orangebook *<br/>网站:<a href="http://www.cr ...

  8. Surface,送我都不要

    本文作于前几天,由于今天的突发新闻,已作了修订. Nokia的着火史 自从Elop那篇着火的平台备忘录出炉,Nokia的杯具就已经造成,唯一令人不解的就是:Elop为什么还没有被开除? 距离这个备忘录 ...

  9. 关于运行robotium提示连接不上jar问题

    robotium运行测试helloworld报错: java.lang.NoClassDefFoundError: com.jayway.android.robotium.solo.Solo at c ...

  10. UI_UIImageView 基本操作

    UI_UIImageView 经常用法 // 使用ImageView 通过 name 找到图片 UIImage *image = [UIImage imageNamed:@"bg_2&quo ...