趣学算法NYOJ加勒比海盗船

题目描述:
在北美洲东南部,有一片神秘的海域,那里碧海蓝天、阳光明媚,这正是传说中海盗最活跃的加勒比海(Caribbean Sea)。17世纪时,这里更是欧洲大陆的商旅舰队到达美洲的必经之地,所以当时的海盗活动非常猖獗,海盗不仅攻击过往商人,甚至攻击英国皇家舰……

有一天,海盗们截获了一艘装满各种各样古董的货船,每一件古董都价值连城,一旦打碎就失去了它的价值。虽然海盗船足够大,但载重量为C,每件古董的重量为wi,海盗们该如何把尽可能多数量的宝贝装上海盗船呢?

输入描述:
第一行是一个整型数m(m<100)表示共有m组测试数据。
每组测试数据的第一行是两个整数c,n(1<c,n<10000)表示该测试数据载重量c及古董的个数n。
第二行是n个数,分别表示第i个古董的重量。
输出描述:
对于每一组输入,输出能装入的古董最大数量。
每组的输出占一行
样例输入:
复制
2
30 8
4 10 7 11 3 5 14 2
45 10
5 12 7 3 20 9 15 11 8 32
样例输出:
5
6
这个题比较简单,只需要对重量进行排序,然后tmp变量记录从小到大的当前累加之和,在与限制的重量进行比较,只要小于就可让cnt++,直到无法再放入东西为止,最后就得到答案

#include<iostream>
#include<algorithm>
using namespace std;
int main(){
	int num;
	int weight,shu;
	int value[10001];
	cin>>num;
	while(num--){
		cin>>weight>>shu;
		for(int i=0;i<shu;i++)
			cin>>value[i];
		sort(value,value+shu);
		int tmp=0;
		int cnt=0;
		for(int i=0;i<shu;i++){
			if(tmp<=weight){
				if(tmp+value[i]<=weight){
				
				tmp+=value[i];
				cnt++;
			}
			}
		}
		cout<<cnt<<endl;
	}
	return 0}

猜你喜欢

转载自blog.csdn.net/qq_41319370/article/details/82975061