博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HOJ 2245 浮游三角胞(数学啊 )
阅读量:5905 次
发布时间:2019-06-19

本文共 1588 字,大约阅读时间需要 5 分钟。

题目链接:

Time Limit: 500 MS Memory Limit: 50000 K
Total Submit: 129(38 users) Total Accepted: 66(34 users) Rating: Special Judge: No
Description

如图所看到的。Zoidtrip是一个休闲向小游戏……

玩家须要操纵一个以斜向下四十五度速度v不停前进的三角胞,不停地避开水平障碍物,每次点击屏幕能够变换行进方向。[能够将斜向左(右)45°变换为斜向右(左)45°]
如今,有n层障碍物。第i层障碍物能够从横坐标l[i]~r[i]的范围内穿过去(包含l[i]与r[i]),第i层障碍物与第i-1层障碍物之间的距离为d[i]。
请问,假定在能够无限变换方向的条件下,最多能够前进至第几层?
我们规定玩家出生位置为第0层、横坐标为0的地方。
你能够在随意实数时刻进行方向变换。

Input
多组測试数据。
每组測试数据第一行为两个正整数 n和v。
接下来n行,每行3个整数l[i] , r[i] , d[i]。
( N <= 2000000。0 <= 全部数据 < 2^31 )
Output
对于每组数据。输出一行,包括一个整数,代表最多前进至的层数。
Sample Input
3 7
1 3 1
4 10 5
8 10 1
4 1
1 1 1
2 5 10
1 1 1
3 5 2
Sample Output
2
4
Hint

“第i层障碍物与第i-1层障碍物之间的距离为d[i]”

因此d[1]是第一层和第零层的距离。

例子1解释例如以下:

我们能够出生位置向右下移动至第一层坐标为1的地方。
接下来能够继续一直向右下移动至第二层坐标为6的地方。

但不管怎样也无法移动至第三层的8~10之间。

例子2说明例如以下:

(0,0)->(1,1)->(2,2)->(3,1)->(4,3)
因此到达第四层。

Source
哈尔滨理工大学第五届ACM程序设计竞赛

PS:

把 三角胞在每一层能走到的且满足能避开障碍物的最左和最右的距离找出来!

代码例如以下:

#include 
#include
#include
using namespace std;#define LL long long#define maxn 2000047LL l[maxn], r[maxn], d[maxn];int main(){ LL n, v; while(scanf("%lld%lld",&n,&v)!=EOF) { LL L = 0,R = 0; int ans = 0; for(int i=0; i
r[i]) { LL t = r[i]; r[i] = l[i]; l[i] = t; } L-=d[i]; R+=d[i]; L = max(l[i],L); R = min(r[i],R); if(L > R) { break; } ans++; } if(v == 0) ans = 0; printf("%d\n",ans); } return 0;}

转载地址:http://ckcpx.baihongyu.com/

你可能感兴趣的文章
使用ASP.NET Atlas SortBehavior实现客户端排序
查看>>
图像滤镜处理算法:灰度、黑白、底片、浮雕
查看>>
Office文档出错的几种原因与解决方法
查看>>
正则表达式 学习笔记1.1
查看>>
AssetBundle进阶内存优化(Unity 4.x)
查看>>
《从零开始学Swift》学习笔记(Day 40)——析构函数
查看>>
Exchange2003-2010迁移系列之十,Exchange证书攻略
查看>>
extmail集群的邮件负载均衡方案 [lvs dns postfix]
查看>>
更改UIView的背景
查看>>
APUE第15章学习扎记之程序的存储区布局试验
查看>>
ubuntu升级16.04 inter idea 中文输入法无效
查看>>
三目运算判断jsp脚本里面的值
查看>>
sshtunnel在本地访问云服务器mysql
查看>>
小蚂蚁学习APP接口开发(1)—— json方式封装通信接口
查看>>
我的友情链接
查看>>
CDN相关
查看>>
Tomcat的设置4——Tomcat的体系结构与设置基于端口号的虚拟主机
查看>>
我的友情链接
查看>>
ftp协议基础
查看>>
访问共享经常中断
查看>>