2142: 逛超市
时间限制: 1 Sec 内存限制: 128 MB提交: 82 解决: 43
[提交] [状态] [讨论版] [命题人:admin]
题目描述
“别人总说我瓜,其实我一点也不瓜,大多数时候我都机智的一批“
我宝儿姐背包学的太差了,你们谁能帮我解决这道题,我就让他做我的男朋友!宝儿姐现在在逛超市,超市里的种类实在是太多了,每种都有很多很多(无限个),每种每个都有一个能给我的开心值,但是宝儿姐又不希望太开心了,希望获得的开心值小于m,防止乐极生悲。请你帮忙计算一下,从这n种类的物品中挑出4个(不是4种)获得不超过m的最大开心值是多少吧
我宝儿姐背包学的太差了,你们谁能帮我解决这道题,我就让他做我的男朋友!宝儿姐现在在逛超市,超市里的种类实在是太多了,每种都有很多很多(无限个),每种每个都有一个能给我的开心值,但是宝儿姐又不希望太开心了,希望获得的开心值小于m,防止乐极生悲。请你帮忙计算一下,从这n种类的物品中挑出4个(不是4种)获得不超过m的最大开心值是多少吧
输入
多实例输入
第一行两个整数n和m,代表超市里物品的种类数目(n<=1000)和希望获得的开心值上限(m<=1e6)
当n和m同时为0表示输入结束。
接下来一行n个整数,代表n种物品中单个能带来的开心值(同种物品单个开心值相同,且小于等于1e4)
第一行两个整数n和m,代表超市里物品的种类数目(n<=1000)和希望获得的开心值上限(m<=1e6)
当n和m同时为0表示输入结束。
接下来一行n个整数,代表n种物品中单个能带来的开心值(同种物品单个开心值相同,且小于等于1e4)
输出
一个整数,代表宝儿姐能获得的不超过m的最大开心值。
样例输入
2 20
1 2
0 0
样例输出
8
#include <iostream> #include <cstdio> #include <map> #include <string> #include<cstring> #include<algorithm> #include<vector> typedef long long ll; const int maxn = 1010000; using namespace std; int n, m,res; int a[maxn]; int b[maxn]; int main() { int n, m; while (cin >> n >> m,n!=0&&m!=0) { int k = 0; for (int i = 0; i < n; i++) scanf("%d", &a[i]); for (int i = 0; i < n; i++) for (int j = 0; j < n; j++) b[k++] = a[i] + a[j]; sort(b, b + k); int Max = -1; for (int i = 0; i < k; i++) { int temp = upper_bound(b, b + k, m - b[i]) - b; if (temp - 1 < 0) continue; Max = max(Max, b[i] + b[temp - 1]); } cout << Max << endl; } return 0; }