独木桥,洛谷之提高历练地,神奇的解法

正题

      这题很搞笑啊~~

      下面是转载洛谷 I_am_wx的题解。

      你在桥上看风景,看风景的人在轰炸机上看着你。

      首先自行脑补一下,假装你正在20000米高空的轰炸机上用高倍显微镜望远镜默默欣赏士兵离开,你会发现什么东西?一堆花花绿绿的迷彩服在移动。(不是鬼片!不是鬼片!不是鬼片!重要的事情说三遍)

       那么当两个士兵撞在一起时,从你的视角看会发生什么?当然他们认为他们都掉头了,但因为你在特高的地方,你会认为他们“穿过”了对方。换言之,这与他们相互穿过并没有任何区别。

       然后我们就可以把士兵分开了。比方说有一个士兵在位置3,开始时向右,那么一定有一个士兵在两秒后在位置5。虽然这两个家伙可能不是同一个人,但由于士兵都是相同的,我们可以认为他们相同。

       那么我们就可以把所有士兵分开。首先,我们把他们一个个读进去。然后,对于每一个士兵,他有向左和向右两种选择。设士兵在位置p,如果向左,需要p时间单位;向右,需要L-p+1个。分别取max和min,更新答案即可。

      我和你相撞就相当于,以后的路你帮我走,我帮你走。所以要决定的就是开始的状态是向左还是向右。

#include<cstdio>
#include<cstdlib>
#include<cstring>

int n,l;
int max=0,min=0;

int mmax(int x,int y){
	return x>y?x:y;
}

int mmin(int x,int y){
	return x<y?x:y;
}

int main(){
	scanf("%d %d",&l,&n);
	for(int i=1;i<=n;i++){
		int x;
		scanf("%d",&x);
		max=mmax(max,mmax(x,l+1-x));
		min=mmax(min,mmin(x,l+1-x));
	}
	printf("%d %d",min,max);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值