山头狙击战

山头狙击战

描述

为了掩护大部队,英雄杰克被敌人包围在某山头。但他有足够的弹药,凭借自己的勇敢,完全可以将涌上来的敌人一个一个干掉。杰克是个神枪手,只要他的枪膛中有子弹,他就能将在他射程m(用从敌人位置到山头的直线距离算)以内的一个敌人瞬间射杀。但如果在射程内没有敌人,出于节约子弹考虑,杰克会等待敌人靠近然后射击。 正当杰克为自己的强大而自我膨胀时,他忽然发现了一个致命的失误:他携带的枪是单发枪,每射出一发子弹都必须花K秒钟的时间装子弹。而凶残的敌人才不会花时间等你换子弹呢。他们始终在以1m/s的速度接近山头。而如果在一个敌人到达山头时杰克无法将他击毙,那么我们可怜的杰克就将牺牲在敌人的刺刀下。现在杰克向你发出求助:要保住自己的性命并且歼灭所有敌人,杰克最多只能用多少时间给枪装上一发子弹? 说明:假设一开始杰克的枪中就有一发子弹,并且一旦确定一个装弹时间,杰克始终会用这个时间完成子弹的装卸。希望你编写程序计算出杰克最多只能用多少时间给枪装上一发子弹,帮助杰克脱离险境。

输入

 

第一行有两个整数n和m,n代表敌人个数,m代表杰克的射程。接下来有n行,每行一个整数di,代表每个敌人一开始相对山头的距离(单位为米)。

输出

 

输出一行,仅有一个整数,代表杰克最多能用的换弹时间(单位为秒)。

输入样例 1 

6 100
236
120
120
120
120
120

输出样例 1

25
#include<bits/stdc++.h>
using namespace std;
int a[1000]; //距离 
int n,m;//m射程,n敌人数 
bool check(int t)
{
	int tm=a[0]-m;;
	if(tm>0)
	{
		for(int i=0;i<n;i++)
		  a[i]-=tm;
	}
	tm=t;
	for(int i=1;i<n;i++)
	{
		if(a[i]-tm>=0)
		   tm+=t;
		else
		   return 0;  
	}
	return 1;
}
int main()
{
	cin>>n>>m;
	for(int i=0;i<n;i++)
	   cin>>a[i];
	sort(a,a+n);
	int mt=0,Mt=1000000,t,k;
	while(Mt-mt>1)
	{
		t=(mt+Mt)/2;
		if(check(t))
		   mt=t,k=t;
		else
		{
			Mt=t;
		}   
	}
	cout<<k; 
} 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值