zoukankan      html  css  js  c++  java
  • 2142: 逛超市(zznuoj)

    2142: 逛超市

    时间限制: 1 Sec  内存限制: 128 MB
    提交: 82  解决: 43
    [提交] [状态] [讨论版] [命题人:admin]

    题目描述

    “别人总说我瓜,其实我一点也不瓜,大多数时候我都机智的一批“
    我宝儿姐背包学的太差了,你们谁能帮我解决这道题,我就让他做我的男朋友!宝儿姐现在在逛超市,超市里的种类实在是太多了,每种都有很多很多(无限个),每种每个都有一个能给我的开心值,但是宝儿姐又不希望太开心了,希望获得的开心值小于m,防止乐极生悲。请你帮忙计算一下,从这n种类的物品中挑出4个(不是4种)获得不超过m的最大开心值是多少吧

    输入

    多实例输入
    第一行两个整数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;
    }
    

      

  • 相关阅读:
    数据结构与算法(二)(栈、队列)
    数据结构与算法(一)(数组、线性查找、二分查找)
    ssm项目中常用的上传文件
    安全防御之防xss、SQL注入、与CSRF攻击
    int i=i++;和i=++i;和i++
    关于@Autowired和@Resource注解区别
    通过idea创建Maven项目整合Spring+spring mvc+mybatis
    深入理解java虚拟机(一)
    java中栈,堆,方法区
    SpringBoot+mybatis配置pagehelper实现基础分页
  • 原文地址:https://www.cnblogs.com/kangdong/p/9440994.html
Copyright © 2011-2022 走看看