题目描述

给定n个选手,将他们分成若干只队伍。其中第i个选手要求自己所属的队伍的人数大等于a[i]人。

在满足所有选手的要求的前提下,最大化队伍的总数。

注:每个选手属于且仅属于一支队伍。

输入输出格式

输入格式:

第一行一个整数n,表示人数。

以下n行,每行一个整数表示a[i]。

输出格式:

输出队伍总数的最大值。数据保证有解。

输入输出样例

输入样例#1: 复制

5
2
1
2
2
3
输出样例#1: 复制

2

题意:中文题就不说了

题解:刚开始我想的是贪心,先让序列从小到大排序,因为至少要用a[i]个人,所以我秉承着越少越好的原则,从a[i]大的下手,把a[i]大的先填满,最后如果剩下的人数不足以满足,他们的a[i]那就把他们加到其他队伍中去。

但是有个致命的缺点,举例说明:

这里只写出来a[i]值:

1  1   1   3   3   1   1   1

这种情况如果我们从大考虑,把两个三都分别用1 1 3来凑齐,剩下的自己一组,那么队伍数就会少于把3 3 1凑在一起剩下的自己一组,因此我们还需要在中间判断这个a[i]要不要和之前比它大的一组,还是另外开一组

所以就有了现在的方法:

还让a[i]从小到大排序,这一次从a[i]小的下手,如果a[i]所需要的人数大于这个i,那么之前的全部加起来就没有办法凑成一个队伍满足要求,所以让dp值不变仍然为0。往后面找,如果找到一个i-a[i]大于0的,那就判断

1、如果这个i-a[i]==0,那就可以让dp[i]=dp[i-a[i]]+1

2、如果这个大于0,因为题目上要求每个人必须属于一个队伍,所以你找的这个dp[i-d[i]]必须大于0,大于0说明它包含了之前的比他a[i]值小的a[i],这样就符合了题意

而且为了找到最优解,它还要去看一下它的上一个(即dp[i-a[i]-1])是否满足要求(一般都要满足越往后面找后面的一定要比前面的尽量更优)

就只能讲成这样了<_>

 1 #include<stdio.h>
2 #include<string.h>
3 #include<iostream>
4 #include<algorithm>
5 using namespace std;
6 const int maxn=1000005;
7 int v[maxn],dp[maxn];
8 int main()
9 {
10 int n;
11 scanf("%d",&n);
12 for(int i=1;i<=n;++i)
13 {
14 scanf("%d",&v[i]);
15 }
16 sort(v+1,v+1+n);
17 for(int i=1;i<=n;++i)
18 {
19 if(i-v[i]-1>0 && dp[i-v[i]]>0 && dp[i-v[i]-1]>0 || i-v[i]==0 || i-v[i]-1==0)
20 dp[i]=max(dp[i-v[i]]+1,dp[i-v[i]-1]+1);
21 else if(i-v[i]>0 && dp[i-v[i]]>0 || i-v[i]==0)
22 dp[i]=dp[i-v[i]]+1;
23 else dp[i]=0;
24 }
25 printf("%d\n",dp[n]);
26 }

P2062 分队问题(DP)的更多相关文章

  1. 洛谷P2062 分队问题(dp)

    题意 题目链接 给定n个选手,将他们分成若干只队伍.其中第i个选手要求自己所属的队伍的人数大等于a[i]人. 在满足所有选手的要求的前提下,最大化队伍的总数. 注:每个选手属于且仅属于一支队伍. So ...

  2. P2062 分队问题(贪心orDP)

    题目描述 给定n个选手,将他们分成若干只队伍.其中第i个选手要求自己所属的队伍的人数大等于a[i]人. 在满足所有选手的要求的前提下,最大化队伍的总数. 注:每个选手属于且仅属于一支队伍. 输入输出格 ...

  3. 洛谷 P2062 分队问题

    这题太毒了....一开始就是死活想不到,结果看了很多遍题解,重新做的时候还是做不出来.. 好像有一点被错误的题解误导了? #include<cstdio> #include<algo ...

  4. 洛谷P2062 分队问题

      这是一道普及/提高- 然后你懂的,贪心扫一遍就可以了. 不懂提交人数那么少. //Serene #include<algorithm> #include<iostream> ...

  5. 动态规划dp专题练习

    貌似开坑还挺好玩的...开一个来玩玩=v=... 正好自己dp不是很熟悉,就开个坑来练练吧...先练个50题?小目标... 好像有点多啊QAQ 既然是开坑,之前写的都不要了! 50/50 1.洛谷P3 ...

  6. 第十六届浙江大学宁波理工学院程序设计大赛 D 雷顿女士与分队hard version(dp)

    题意 链接:https://ac.nowcoder.com/acm/contest/2995/D来源:牛客网 卡特莉接到来自某程序设计竞赛集训队的邀请,来为他们进行分队规划. 现在集训队共有n名选手, ...

  7. FJNU Fang G and his Friends(状压DP)题解

    Description     众所周知,fang G 有很多小伙伴,有一天,Fang G 打算带他们去玩有趣的游戏OOXX,这个游戏需要分成两组,有趣的是,每个人互相之间都有一个满意度,大家都想和自 ...

  8. P2577 [ZJOI2005]午餐 状压DP

    题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...

  9. dp专题练习

    顺便开另外一篇放一些学过的各种dp dp总结:https://www.cnblogs.com/henry-1202/p/9194066.html 开坑先放15道题,后面慢慢补 目标50道题啦~~,目前 ...

随机推荐

  1. LeetCode707 设计链表

    设计链表的实现.您可以选择使用单链表或双链表.单链表中的节点应该具有两个属性:val 和 next.val 是当前节点的值,next 是指向下一个节点的指针/引用.如果要使用双向链表,则还需要一个属性 ...

  2. LeetCode 371两数之和

    题目描述: 不使用运算符 + 和 - ​​​​​​​,计算两整数 ​​​​​​​a .b ​​​​​​​之和. 思路: 既然不能使用运算符操作就要考虑到,位运算的加法. 加法有进位的时候和不进位的时候 ...

  3. 使用正则表达式和urllib模块爬取最好大学排名信息

    题目 使用urllib模块编程实现爬取网站的大学排名. (网址:http://www.zuihaodaxue.cn/zuihaodaxuepaiming2016.html) (1)获取网站页面,分析代 ...

  4. 音视频入门-20-BMP、PNG、JPG、GIF静态图生成GIF动态图

    * 音视频入门文章目录 * 静态图 -> 动态图 前面 [18-手动生成一张GIF图片] 和 [19-使用giflib处理GIF图片] 生成的 GIF 每一帧都是一个颜色,平时用到的 GIF 每 ...

  5. cmd的终结工具cmder

    常用快捷键 win+alt+t  打开任务设置窗口 win+alt+k 打开快捷键设置窗口 自定义屏幕分割窗口快捷键: ctl+shift+s 水平按50%比例分割 ctl+shift+v 垂直按50 ...

  6. LTH7锂电池充放电IC完整方案

    内容目录: A,LTH7贴片5脚充电芯片    PW4054 1, 单节的锂电池保护电路     单节为3.7V锂电池(也叫4.2V)和3.8V锂电池(也叫4.35V) 2, 单节的锂电池充电电路   ...

  7. 同一份数据,Redis为什么要存两次

    前言 在 Redis 中,有一种数据类型,当在存储的时候会同时采用两种数据结构来进行分别存储,那么 Redis 为什么要这么做呢?这么做会造成同一份数据占用两倍空间吗? 五种基本类型之集合对象 Red ...

  8. 阿里云VOD(三)

    一.视频播放器 参考文档:https://help.aliyun.com/document_detail/125570.html?spm=a2c4g.11186623.6.1083.1c53448bl ...

  9. 前端知识(二)04-vue-element-admin-谷粒学院

    目录 一.vue-element-admin 1.简介 2.安装 二.vue-admin-template 1.简介 2.安装 一.vue-element-admin 1.简介 vue-element ...

  10. 数据分析——Numpy/pandas

    NumPy NumPy是高性能科学计算和数据分析的基础包.部分功能如下: ndarray, 具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组. 用于对整组数据进行快速运算的标准数学函数(无需编 ...