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. Python 2.7 学习笔记 基本语法和函数定义

    本文介绍下python的基本语法 一.变量定义 不需要说明类型,也不需要像js等脚本语言使用var等标识符.直接声明即可,如: num=1 说明:上面语句声明了一个变量num,并在声明时初始化值为 1 ...

  2. 二维码的妙用:通过Zxing实现wifi账号password分享功能

    二维码是搭载信息的一种载体,通过二维码能够传递名片.网址.商品信息等,本文讲到二维码的第二种妙用:通过二维码实现wifi账号和password分享. 关于二维码的基础知识,请訪问:二维码的生成细节和原 ...

  3. POJ 2485:Highways(最小生成树&amp;&amp;prim)

    Highways Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 21628   Accepted: 9970 Descrip ...

  4. 如何将一个Jsp网站打包发布(发布为War文件)

    链接地址:http://blog.csdn.net/luohuijun619/article/details/4867131 版权声明:本文为博主原创文章,未经博主允许不得转载. 网站做完后,并不是直 ...

  5. BZOJ 1704: [Usaco2007 Mar]Face The Right Way 自动转身机( 贪心 )

    贪心...先枚举k, 然后从左往右扫一遍, 发现位置p的牛的状态不符合就将 [p, p + k ) 的牛都转身, 假如p + k - 1 已经超过了最右边牛的位置那这个k就不符合要求. 符合要求的就可 ...

  6. NOI2007 生成树计数

    题目 首先我要吐槽,这题目就是坑,给那么多无用的信息,我还以为要根据提示才能做出来呢! 算法1 暴力,傻傻地跟着提示,纯暴力\(40\)分,高斯消元\(60\)分. 算法2 DP!一个显然的东西是,这 ...

  7. SqlServer和Oracle中一些常用的sql语句6 存储过程

    --不带参数的存储过程 CREATE procedure proc_sql1 as begin declare @i int set @i=0 while @i<26 begin print c ...

  8. 用 PS 复制权限

    用 PS 复制权限 我们要把源计算机上的文件权限复制到目的计算机上. get-acl .\s.txt | Export-Clixml sddl.xml 把 s.txt 文件的权限保存到 sddl.xm ...

  9. Java--Eclipse关联Java源码

    打开Eclipse,Window->Preferences->Java 点Edit按钮后弹出: 点Source Attachment后弹出: 选择Java安装路径下的src.zip文件即可 ...

  10. Swift - 添加、修改、删除通讯录联系人

    使用AddressBook.framework框架,我们除了可以很方便的获取通信录里的联系人.同时,还能对通讯录进行新增.修改.删除联系人操作. (注意:这些操作同查询一样,首先需要发起授权请求) 1 ...