XYNUOJ 暑期集训第二次测试 A - 独木舟

 

A - 独木舟

 魔法学院放暑假了,WC和他的一帮魔友一起去弗尔夫斯基山脉玩。莫伊拉同学突然想划船到对岸找被削的Mercy玩,这里的每一艘船都是同一型号,能承受的重量都是一样的,并且每艘船都可以坐一个或者两个人。WC他们共有n个人,现在我们知道他们每个人的质量,而且每个人体重也不超过船的承重。可惜经费有限,他们必须租尽可能少的船,请问他们最少要租几艘船? 

Input

第一行包含两个正整数n 和m ,n<=10^4,m<=2*10^9,表示人的数量和船的最大承重。 接下来n行,每行一个正整数,表示每个人的体重。体重不超过m。 

Output

一行一个整数表示最少需要的独木舟数。

Sample Input

3 6
1
2
3

Sample Output

2
#include<cstdio>
#include<algorithm>
#define M 100000
using namespace std;

int cmp(int x,int y)
{
	return x>y;
}

int main()
{
	int   n,m;
	int  a[M];
	int count=0;

	scanf("%d%d",&n,&m);

	for(int i=0; i<n; i++)
		scanf("%d",&a[i]);

	sort(a,a+n,cmp);

	int k;

	for(int i=0; i<n; i++)
	{
		k=m;//将小船的载重量记录下来
		if(a[i]!=0)
		{
			for(int j=0; j<n; j++)
			{
				k=k-a[i];//用小船的载重量减去已经上船人的重量
				a[i]=0;//上船之后,将人的重量归零
				if(a[j]<=k&&a[j]>0)//如果有人的体重<=小船当前的载重量,则两人可以一同乘船
				{
					a[j]=0;//将第二个人的体重归零
					break;//因为一共只能做两个人,所以退出循环
				}
			}
			count++;//小船数量增加1
		}
	}
	printf("%d\n",count);
	return 0;
}
//大佬的代码
#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
int main() {
	int n,m,a[10005];
	while(cin>>n>>m) {
		for(int i=0; i<n; i++)
			cin>>a[i];
		sort(a,a+n);
		int ans=0;
		for(int i=0,j=n-1; i<=j;) {
			if(a[j]+a[i]<=m) //如果能载两个人 
				i++;
			ans++;
			j--;
		}
		cout<<ans<<endl;
	}
}

猜你喜欢

转载自blog.csdn.net/yxy602843889/article/details/81291255