noip普及组2007 纪念品分组
纪念品分组
描述
元旦快到了,校学生会让乐乐负责新年晚会的纪念品发放工作。为使得参加晚会的同学所获得 的纪念品价值相对均衡,他要把购来的纪念品根据价格进行分组,但每组最多只能包括两件纪念品, 并且每组纪念品的价格之和不能超过一个给定的整数。为了保证在尽量短的时间内发完所有纪念品,乐乐希望分组的数目最少。
你的任务是写一个程序,找出所有分组方案中分组数最少的一种,输出最少的分组数目。
【限制】
50%的数据满足: 1 <=n <= 15
100%的数据满足: 1 <= n <= 30000, 80 <= W <= 200
格式
输入格式
第1行包括一个整数w,为每组纪念品价格之和的上限= 第2行为一个整数n,表示购来的纪念品的总件数G
第3-n+2行每行包含一个正整数Pi (5 <= Pi <= w3)w表示所对应纪念品的价格。
输出格式
仅1行,包含一个整数, ep最少的分组数目合
样例1
样例输入1
100
9
90
20
20
30
50
60
70
80
90
样例输出1
6
限制
各个测试点1s
这题是一题贪心题,我们把价格都排一遍序,然后用两个指针l,r表示左右端点,如果两大的和小的不超出限制,我们就把它们分为一组,否则大的单独为一组
#include <iostream>
#include <algorithm>
using namespace std;
//ifstream cin("group.in",ios :: in);
//ofstream cout("group.out",ios :: out);
int a[30001],n,m;
int main() {
  ios :: sync_with_stdio(false);  //流的加速
  cin >> m >> n;
  for(int i = 1;i <= n;i++) cin >> a[i];
  sort(a+1,a+n+1);  //排序,规则:从小到大
  int l = 1,r = n,ans = 0;
  while (l <= r) {  //拿小的和大的分
    if (a[l]+a[r] <= m && l != r) {
    //如果不超过限制且l和r不同
      ans++;
      l++;
      r--;
    } else {
    //否则大的单独分为一组
      ans++;
      r--;
    }
  }
  cout << ans;
  return 0;
}
noip普及组2007 纪念品分组的更多相关文章
- noip普及组2007 奖学金
		奖学金 描述 某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金.期末,每个学生都有3门课的成绩:语文.数学.英语.先按总分从高到低排序,如果两个同学总分相同,再按语文成绩 ... 
- noip普及组2007 守望者的逃离
		守望者的逃离 描述 恶魔猎手尤迪安野心勃勃,他背叛了暗夜精灵,率领深藏在海底的娜迦族企图叛变.守望者在与尤迪安的交锋中遭遇了围杀,被困在一个荒芜的大岛上.为了杀死守望者,尤迪安开始对这个荒岛施咒,这座 ... 
- noip普及组2007 Hanoi双塔问题
		Hanoi双塔问题 描述 给定A,B,C三根足够长的细柱,在A柱上放有2n个中间有孔的圆盘,共有n个不同的尺寸,每个尺寸都有两个相同的圆盘,注意这两个圆盘是不加区分的.现要将这些圆盘移到C柱上,在移动 ... 
- 2016.9.17初中部下午NOIP普及组比赛总结
		2016.9.17初中部下午NOIP普及组比赛总结 2016.09.17[初中部 NOIP普及组 ]模拟赛 最近几次的题目都不是自己擅长的啊... 不过含金量挺高的,也好... 进度: 比赛:0+0+ ... 
- 2321. 【NOIP普及组T1】方程
		2321. [NOIP普及组T1]方程 时间限制: 1000 ms 空间限制: 262144 KB 题目描述 
- [NOIP普及组2011]装箱问题
		目录 链接 博客链接 题目链接 题目内容 题目描述 格式 输入 输出 样例 输入 输出 前缀知识 题解 题目名称:装箱问题 来源:2011年NOIP普及组 链接 博客链接 CSDN 洛谷博客 题目链接 ... 
- [NOIP普及组2001]最大公约数和最小公倍数问题
		目录 链接 博客链接 题目链接 题目内容 题目描述 格式 输入 输出 数据 样例 输入 输出 说明 题目名称:最大公约数和最小公倍数问题 来源:2001年NOIP普及组 链接 博客链接 CSDN 洛谷 ... 
- 2016.8.15上午纪中初中部NOIP普及组比赛
		2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ... 
- 2016.9.15初中部上午NOIP普及组比赛总结
		2016.9.15初中部上午NOIP普及组比赛总结 2016.09.15[初中部 NOIP普及组 ]模拟赛 又翻车了!表示时超和空超很可恨! 进度 比赛:AC+0+0+20=120 改题:AC+80+ ... 
随机推荐
- JavaWeb 后端 <十> 之 数据池 C3P0 DPCB JNDI
			一.数据库连接池原理:(理解) //模拟数据库连接池的原理 public class ConnectionPoolDemo { private static List<Connection> ... 
- bootstrap栅栏系统css中的col-xs-*、col-sm-*、col-md-* 的意义以及 bootstrap一个标签中,同时有 col-xs , col-sm , col-md , col-lg的理解
			摘要: bootstrap栅栏系统css中的col-xs-*.col-sm-*.col-md-* 的意义: .col-xs- 超小屏幕 手机 (<768px) .col-sm- 小屏幕 平板 ( ... 
- 高效测试用例组织算法pairwise之Python实现
			------------------------------------------本文专为<光荣之路培训 >原创,如有转载请注明出处--------------------------- ... 
- PowerShell 远程执行任务
			在 linux 中我们可以使用 SSH 执行各种远程操作,同样的在 windows 平台上我们可以通过 PowerShell 获得类似的能力.本文将介绍通过 PowerShell 执行远程操作的基本信 ... 
- linux系统编程之文件IO
			1.打开文件的函数open,第一个参数表示文件路径名,第二个为打开标记,第三个为文件权限 代码: #include <sys/types.h> #include <sys/stat. ... 
- 20170713_js闭包/匿名函数/作用域
			js:闭包 var getNum; function getCounter() { var n = 1; var inner = function () {return n++; } console. ... 
- 【翻译】React vs Angular: JavaScript的双向性
			翻译原文链接:https://blog.prototypr.io/react-vs-angular-two-sides-of-javascript-b850de22b413 我的翻译小站:http:/ ... 
- iOS App签名的原理
			前言 相信很多同学对于iOS的真机调试,App的打包发布等过程中的各种证书.Provisioning Profile. CertificateSigningRequest.p12的概念是模糊的,导致在 ... 
- 三.GC相关之三分钟认识GC算法
			GC算法慢慢演化,进化到了现在的分代GC.其进化过程 标记-清除算法 –> 标记-复制算法 –> 标记-整理算法 –> 分代算法. 在介绍算法之前,我们知道Java是动态加载.其特点 ... 
- nodejs01--什么是nodejs,nodejs的基本使用
			nodejs使用范围 -直接在cmd命令行运行,在你的电脑上直接运行 -可以搭建一个web服务器(express,koa) -一些基本的使用 -modules是如何工作的 -npm管理modules ... 
