POJ 2674 Linear world(弹性碰撞)
| Time Limit: 3000MS | Memory Limit: 65536K | |
| Total Submissions: 4426 | Accepted: 1006 |
Description
Not so long time ago people used to believe that they live on 2-D world and if they will travel long enough in one direction, they will fall down over the edge. Even when it was proved that the Earth is rounded some of them were still afraid to travel to the southern hemisphere.
Try to imagine one 1-D (linear) world. On such world there are only two possible directions (left and right). All inhabitants of such world were created exactly at the same time and suddenly all of them start to move (all with same constant velocity) in one or the other direction. If two inhabitants encounter each other, they politely exchange greetings and then they turn around and start to move in an opposite direction. When an inhabitant reaches the end of the world he falls away and disappears.
Your task is to determine, for a given scenario of creation, which inhabitant and when (counting from the moment of creation) will be the last one to fall away. You can assume that the time required to exchange greetings and turn around is 0.
Input
N
LV
DIR POS NAME
...
The first line defines the number of inhabitants (N<32000). Data set starting with value N=0 represents the end of the input file. The second line contains length of the world L(float) and velocity of inhabitants V(float). Both values are always positive. In next N lines the data about inhabitants are given in an order of increasing POS (positive direction):
DIR – initial direction ('p' or 'P' for positive and 'n' or 'N' for negative)
POS – position in the time of creation (0<=POS<=L)
NAME – name of inhabitant (string up to 250 characters)
Input values within one line are separated with at least one space and there will be no empty lines in input. You may assume that input is always correct and that each data set has only one unique solution.
Output
Sample Input
1
13.5 2
p 3.5 Smarty
4
10 1
p 1 Helga
n 3 Joanna
p 5 Venus
n 7 Clever
0
Sample Output
5.00 Smarty
9.00 Venus
Source
- 两人碰面后方向相反速度不变,可以认为两人只是交换了名字,
- 仍旧按原来的方向行走。那么只需找出距离端点最远的人,再
- 找出走到端点时此人的名字即可。怎么找出对应的名字呢,
- 只需找出此人走到尽头前遇到的方向相反的人数即可。
- 例如-> <- <- -> <-
- 1 2 3 4 5
- 假设第一个人是最远的,因为2,3,5与之方向相反,因此
- 他的名字将变化三次(5的方向和速度给4,5带着4的速度和方向
- 走到尽头,最后1依次与2,3,4交换)。可以看出1,5之间有
- 方向向右的并不影响(即使有多个也是一样的),1最终只交换
- 三次速度,因为有三人跟他方向相反。而且1最后用的名字一定是
- name[1+3],因为五个人的相对位置是不会变的,也就是说1只可能
- 与2相交换,变成2,而不可能直接与3交换,以此类推,因此最后
- 的名字一定是name[1+3].
#include<cstdio>
#include<algorithm>
#include<iostream>
#include<math.h>
using namespace std;
struct node
{
char d[];
double dec;
char name[];
} c[];
bool cmp(const node& a,const node& b)
{
return a.dec<b.dec;
}
int main()
{
int n,i,j;
double L,V;
while(~scanf("%d",&n))
{
if(!n)break;
scanf("%lf%lf",&L,&V);
for(i=; i<=n; i++)
{
scanf("%s %lf %s",&c[i].d,&c[i].dec,&c[i].name);
}
sort(c+,c+n+,cmp);
int id;
double maL=;
for(i=; i<=n; i++)
{
double R;
if(c[i].d[]=='p'||c[i].d[]=='P')
R=L-c[i].dec;
else R=c[i].dec;
if(R>maL)
{
maL=R;
id=i;
}
}
int ans=;
if(c[id].d[]=='p'||c[id].d[]=='P')
{
for(j=id+; j<=n; j++)
if(c[j].d[]=='n'||c[j].d[]=='N')
ans++;
ans=id+ans;
}
else
{
for(j=id-; j>=; j--)
if(c[j].d[]=='p'||c[j].d[]=='P')
ans++;
ans=id-ans;
}
maL=maL/V;
printf("%13.2lf %s\n",floor(maL*)/100.00,c[ans].name);
}
return ;
}
思路:
很久之前做的一道思路题目了。 这个题比较坑把 记录一下。
两只蚂蚁碰面后相当于不回头一直往前走。
那么我们可以记录下来每只蚂蚁假如不碰面掉落的时间,取个最大值就是最后一只蚂蚁掉落的时间,在把那个时间对应的每只蚂蚁位置记录下来,还在线上的就是最后一只蚂蚁。
#include <iostream>
#include <cstdio>
using namespace std; const int N = ;
char name[N][]; int main()
{
int n;
double l, v; while (cin >> n && n)
{
cin >> l >> v;
int pnum = ;
double pmaxt = -, nmaxt = -;
char dir[];
double pos;
for (int i = ; i < n; i++)
{
scanf("%s%lf%s", dir, &pos, name[i]);
if (dir[] == 'p' || dir[] == 'P')
{
pnum++;
if (pmaxt < )//第一个人(最大的pmax)
pmaxt = (l - pos) / v;
}
else
{
nmaxt = pos / v;//最后一个人(最大的nmax)
}
}
//结果小数点2位之后的数是直接截断的,并不是四舍五入,因此不可以直接打印,要先处理再打印
if (pmaxt > nmaxt)
printf("%13.2lf %s\n", (int)(pmaxt * ) / 100.0, name[n - pnum]);
else
printf("%13.2lf %s\n", (int)(nmaxt * ) / 100.0, name[n - pnum - ]);
}
return ;
}
POJ 2674 Linear world(弹性碰撞)的更多相关文章
- POJ 2674 Linear world
POJ 2674 Linear world 题目大意: 一条线上N只蚂蚁,每只蚂蚁速度固定,方向和坐标不同,碰头后掉头,求最后掉下去那只蚂蚁的时间和名字. 注意两点: 相撞可视为擦肩而过,蚂蚁们不管掉 ...
- poj 2674 线性世界 弹性碰撞
弹性碰撞的题目一般都是指碰到就会掉转方向的一类题目,这里我们可以忽略掉头,仅仅看成擦肩而过,交换名字等等 题意:一条线上N只蚂蚁,每只蚂蚁速度固定,方向和坐标不同,碰头后掉头,求最后掉下去那只蚂蚁的名 ...
- Greedy:Linear world(POJ 2674)
Linear world 题目大意:一些人生活在线性世界中,到达线性世界两端就会消失,两个人的前进方向有两个,相遇会改变各自相遇方向,求最后一个人掉下的人的名字和时间. 其实这一题就是弹性碰撞的模 ...
- POJ 2674
Linear world Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 2448 Accepted: 564 Descr ...
- poj 3684 Physics Experiment 弹性碰撞
Physics Experiment Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1489 Accepted: 509 ...
- POJ:3684-Physics Experiment(弹性碰撞)
Physics Experiment Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3392 Accepted: 1177 Sp ...
- ProgrammingContestChallengeBook
POJ 1852 Ants POJ 2386 Lake Counting POJ 1979 Red and Black AOJ 0118 Property Distribution AOJ 0333 ...
- POJ 3684 Physics Experiment(弹性碰撞)
Physics Experiment Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2936 Accepted: 104 ...
- Greedy:Physics Experiment(弹性碰撞模型)(POJ 3848)
物理实验 题目大意:有一个与地面垂直的管子,管口与地面相距H,管子里面有很多弹性球,从t=0时,第一个球从管口求开始下落,然后每1s就会又有球从球当前位置开始下落,球碰到地面原速返回,球与球之间相碰会 ...
随机推荐
- 【Sizzle学习】之关于【初探 jQuery 的 Sizzle 选择器】这篇文章里的小bug
[题记]不可否认,这篇文章写得非常好,但是今天我在看sizzle源码的时候,发现这文章有一地方说的不妥.重现:当selectors为"p.class1>p.class2",j ...
- CUDA库函数使用笔记与案例(一)
项目合作中需要整合对方公司提供的CUDA代码,因此需要详细学习代码中涉及的cuda函数. CUDA Tool Kit 8.0较完整的官方说明文档: http://docs.nvidia.com/cud ...
- 关于PHP页面显示乱码问题的解决
关于PHP页面显示乱码问题的解决 网页乱码一直是网络编程高手都头痛的问题,我是一个PHP Web编程的初学者,学习当中也遇到了这个问题,查找了相关的资源,总结如下: 一般的中文编码:gb2312,gb ...
- Nginx 作为反向代理优化要点proxy_buffering
当nginx用于反向代理时,每个客户端将使用两个连接:一个用于响应客户端的请求,另一个用于到后端的访问: 那么,可以从如下配置起步: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
- Gradle2.0用户指南翻译——第一章. 介绍
翻译项目请关注Github上的地址:https://github.com/msdx/gradledoc本文翻译所在分支:https://github.com/msdx/gradledoc/tree/2 ...
- VMWare的共享文件的安装指南
引言:笔者这几天基于CentOS 7的精简版按照了一个虚拟机,悲催的是没有图形界面,但是非常需要共享文件的工作,在宿主机以及虚拟机之间实现文件共享,本文将描述如何实现此操作. VMWare菜单按照VM ...
- 从小白开始学习iOS开发
从事iOS开发不经意间,已经两年过去了,记得当初看到OC是,我根本就不知道那些个东西是什么?从开始学习开机,到一个个英文开始,为了能找到工作,愣是耐下心去坚持看下去. 现在回想起来,很是庆幸我没有放弃 ...
- Django model.py表单设置默认值允许为空
blank=True 默认值为blank=Flase,表示默认不允许为空, blank=True admin级别可以为空 null=True 默认值为null=Flase,表示默认不允许为空 nu ...
- [译]SSL/TLS真的被BEAST攻击攻破了吗?真实情况是怎样的?我应该做什么?
原文链接:https://luxsci.com/blog/is-ssltls-really-broken-by-the-beast-attack-what-is-the-real-story-what ...
- js 值和引用
js对值和引用的赋值/传递在语法上没有区别,完全根据值得类型决定 简单值(即标量基本类型值),总是通过值复制的方式来赋值/传递,包括null,undefined,字符串,数字,布尔值和ES6中的sym ...