蚂蚁 POJ1852

题意:有n个蚂蚁,以每秒1cm/s速度在Lcm的竿子上爪巴行.蚂蚁爬到竿子边缘就会掉下去,两只蚂蚁相遇时,由于不能通过,只能反向爬回去,对于每只蚂蚁,我们知道它距离左端距离xi,但我们不知道他们的朝向.求所有蚂蚁落下竿子的最短时间与最长时间.

我们考虑怎么求最短时间:我们这么想,最短的时间意味着走最短的路。如果让每只蚂蚁朝向最短的路(取决于它xi的大小)不就好了吗 显然,小于L/2的会往左走,大于L/2的往右走.

那么这种情况下会不会有蚂蚁相遇呢!不会!因为往左,往右走的蚂蚁以L/2为边界,都是往一个方向走的,由于速度一样,位置不一样所以不会相遇 如图.

然后我们不难得出这样的算法: 对于每一个蚂蚁 令K=min(x,L-x) 这样K就是一个蚂蚁掉下去的最短时间, 遍历每个蚂蚁,求出K的最大值(最后掉下去的) 这样得出的K就是最短时间.

我们再来想怎么求最长时间: 

我们可以这么想啊 如果有一个蚂蚁比较靠左 一个比较靠右 让他们相遇 然后又回头,这样是不是时间比较长.

然后,我们惊奇地发现相遇的时候两个人掉头走的话,是相当于两个人穿透过去的! 也就是说 每一个蚂蚁运动是相对独立的!相遇不会改变它的运动时间!

那么思路就很清晰了 令 K2=max(xi,L-xi),取每个蚂蚁K2的最大值(最墨迹的蚂蚁掉下去决定的).

代码十分简短;...

#include<bits/stdc++.h>
using namespace std;
int main(){ int i,j,k,t,n,len,pos,otpos;cin>>t;
while(t--){
	scanf("%d%d",&len,&n);int maxx=-1,min_=-1;
	for(i=1;i<=n;i++){
		scanf("%d",&pos);
		k=min(len-pos,pos);
		min_=max(min_,k);		
		j=max(len-pos,pos);  maxx=max(maxx,j);
	}
	printf("%d %d\n",min_,maxx);
	
}
return 0;}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

minato_yukina

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值