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. cocos2dx 3.0 飞机大战

    因为课程须要.然后又水平有限.所以写了个飞机大战.加上不会画画.所以图片资源也是从微信apk解压出来的,设计思路參考的偶尔e网事. 闲话不说.先讲一下设计.大体上一共分为3个场景.场景以下是Layer ...

  2. 两个activity之间的数据传递

    1.清单文件第二个activity<activity android:name="com.example.twodatapass.ResultActivity" androi ...

  3. 【转载】CentOS日志系统组成详解

    日志系统有三部分组成:一.使用什么工具记录系统产生的日志信息?      syslog服务脚本管理的两个进程: syslogd.klogd 来记录系统产生的日志信息:      klogd     进 ...

  4. C-01背包问题

    [声明]:非常感谢http://blog.sina.com.cn/s/blog_6dcd26b301013810.html,给我带来的帮助. 看这个图片表示的意思: w[i]表示第i件物品的容积 ,p ...

  5. IOS 新消息通知提示-声音、震动

    一.APNS 1.注册 [[UIApplication sharedApplication] registerForRemoteNotificationTypes:UIRemoteNotificati ...

  6. Wince下实现ImageButton

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

  7. CSS鼠标样式

    1.缺省方式(箭头形状): cursor:default; 2.手型 cursor: pointer;   //通用的cursor: hand;     //为了兼容ie老版本,可以同时写上

  8. 什么是DNS劫持

    我们知道,某些网络运营商为了某些目的,对DNS进行了某些操作,导致使用ISP的正常上网设置无法通过域名取得正确的IP地址.常用的手段有:DNS劫持和DNS污染. 什么是DNS劫持 DNS劫持就是通过劫 ...

  9. bzoj 2623 所罗门的咒语

    这一题其实我没做出来.... 我只是想吐吐槽. 题目要求识别验证码,而且连一点特征信息都不给! 我去偷看了一下数据,然后根据数据生成了图片: 我相信当年没有人能拿分吧. 贴一下transform.cp ...

  10. 清华集训2014 day1 task1 玛里苟斯

    题目 这可算是描述很简单的一道题了!但是不简单. \(S\)是一个可重集合,\(S = \{a_1, a_2, \dots, a_n \}\). 等概率随机取\(S\)的一个子集\(A = \{a_{ ...