题目描述

你刚刚继承了流行的“破锣摇滚”乐队录制的尚未发表的N(1 <= N <= 20)首歌的版权。你打算从中精选一些歌曲,发行M(1 <= M <= 20)张CD。每一张CD最多可以容纳T(1 <= T <= 20)分钟的音乐,一首歌不能分装在两张CD中。CD数量可以用完,也可以不用完

不巧你是一位古典音乐迷,不懂如何判定这些歌的艺术价值。于是你决定根据以下标准进行选择:

1.歌曲必须按照创作的时间顺序在所有的CD盘上出现。(注:第i张盘的最后一首的创作时间要早于第i+1张盘的第一首)

2.选中的歌曲数目尽可能地多

输入输出格式

输入格式:

第一行: 三个整数:N, T, M.

第二行: N个整数,分别表示每首歌的长度,按创作时间顺序排列。

输出格式:

一个整数,表示可以装进M张CD盘的乐曲的最大数目。

输入输出样例

输入样例#1: 复制

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

  1. 3

说明

题目翻译来自NOCOW。

USACO Training Section 3.4

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<cmath>
  5. #include<algorithm>
  6. using namespace std;
  7.  
  8. const int N=;
  9.  
  10. int n,T,m;
  11. int a[N];
  12. int dp[N][N];
  13.  
  14. int main()
  15. {
  16. scanf("%d%d%d",&n,&T,&m);
  17. for(int i=;i<=n;++i)
  18. scanf("%d",a+i);
  19. for(int i=;i<=n;++i)
  20. {
  21. for(int j=m;j>=;--j)
  22. {
  23. for(int k=T;k>=a[i];--k)
  24. {
  25. dp[j][k]=max(dp[j][k],max(dp[j-][T]+,dp[j][k-a[i]]+));
  26. }
  27. }
  28. }
  29. printf("%d",dp[m][T]);
  30. return ;
  31. }

DP版

  1. /*每一首歌都有三种状态。 1、在当前盘里装 2、换张盘装 3、不装 那我们对每首歌进行三种状态的dfs,选到最后找出最大值,且这样做第i张盘的最后一首歌一定比第i+1张盘的第一张早,因为dfs中的歌的编号是递增的*/
  2. #include<iostream>
  3. #include<cstdio>
  4. #include<cstring>
  5. #include<algorithm>
  6. #include<cmath>
  7. using namespace std;
  8.  
  9. int n,m,t,ans=-,tot=;
  10. int cd[],tim[];
  11.  
  12. void dfs(int now,int sum) //now表示当前选到了第几首歌,sum表示选了几首歌
  13. {
  14. if(sum+n+-now<=ans) return; //重要剪枝,如果把后面的歌全装上也不能使答案更新,那么在往下一定不会有更优解,则return
  15. if(now==n+) //歌选完了
  16. {
  17. ans=max(ans,sum);
  18. return;
  19. }
  20. if(cd[tot]>=tim[now]) //在当前盘里装
  21. {
  22. cd[tot]-=tim[now];
  23. dfs(now+,sum+);
  24. cd[tot]+=tim[now];
  25. }
  26. if(tot<m&&t>=tim[now]) //换张盘装
  27. {
  28. tot++;
  29. cd[tot]-=tim[now];
  30. dfs(now+,sum+);
  31. cd[tot]+=tim[now];
  32. tot--;
  33. }
  34. dfs(now+,sum); //不装
  35. }
  36.  
  37. int main()
  38. {
  39. scanf("%d%d%d",&n,&t,&m);
  40. for(int i=;i<=n;i++)
  41. {
  42. scanf("%d",&tim[i]);
  43. }
  44. for(int i=;i<=m;i++)
  45. {
  46. cd[i]=t;
  47. }
  48. dfs(,);
  49. printf("%d",ans);
  50. return ;
  51. }

DFS版

P2736 “破锣摇滚”乐队 Raucous Rockers的更多相关文章

  1. 洛谷P2736 “破锣摇滚”乐队 Raucous Rockers

    P2736 "破锣摇滚"乐队 Raucous Rockers 21通过 52提交 题目提供者该用户不存在 标签USACO 难度普及+/提高 提交  讨论  题解 最新讨论 暂时没有 ...

  2. [luoguP2736] “破锣摇滚”乐队 Raucous Rockers(DP)

    传送门 f[i][j]表示前i首歌放到前j个盘里最多能放多首 ntr[i][j]表示i~j中最多能放进一张盘中多少首歌 ntr数组可以贪心预处理出来. #include <cstdio> ...

  3. “破锣摇滚”乐队(codevs 1444)

    题目描述 Description 你刚刚继承了流行的“破锣摇滚”乐队录制的尚未发表的N(1 <= N <= 20)首歌的版权.你打算从中精选一些歌曲,发行M(1 <= M <= ...

  4. Codevs 1444 “破锣摇滚”乐队

    1444 “破锣摇滚”乐队   题目描述 Description 你刚刚继承了流行的“破锣摇滚”乐队录制的尚未发表的N(1 <= N <= 20)首歌的版权.你打算从中精选一些歌曲,发行M ...

  5. USACO 3.4 Raucous Rockers

    Raucous Rockers You just inherited the rights to N (1 <= N <= 20) previously unreleased songs ...

  6. USACO Section 3.4: Raucous Rockers

    简单的dfs题目 /* ID: yingzho1 LANG: C++ TASK: rockers */ #include <iostream> #include <fstream&g ...

  7. 递推DP UVA 473 Raucous Rockers

    题目传送门 题意:n首个按照给定顺序存在m张光盘里,每首歌有播放时间ti,并且只能完整的存在一张光盘里,问最多能存几首歌 分析:类似01背包和完全背包,每首歌可存可不存,存到下一张光盘的情况是当前存不 ...

  8. DP擎天

    DP! 黄题: 洛谷P2101 命运石之门的选择 假装是DP(分治 + ST表) CF 982C Cut 'em all! 树形贪心 洛谷P1020 导弹拦截 单调队列水题 绿题: 洛谷P1594 护 ...

  9. DP小题集

    P2736 "破锣摇滚"乐队 Raucous Rockers 你刚刚继承了流行的"破锣摇滚"乐队录制的尚未发表的N(1 <= N <= 20)首歌的 ...

随机推荐

  1. iview前台端口设置,跨域端口设置

    前台启动默认端口: 跨域端口: 完毕

  2. Spring Security Oauth2 : Possible CSRF detected

    Spring Security Oauth2 : Possible CSRF detected 使用Spring Security 作为 Oauth2 授权服务器时,在授权服务器登录授权后,重定向到客 ...

  3. 【LeetCode】从排序数组中删除重复项

    给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成. 示例 1 ...

  4. .NetCore/ .NetFramework 机制

    1.每来一个请求,会启动一个线程. 可以通过下面代码打印出来. 这个线程是主线程,如果用异步,会等待异步线程执行完毕才会返回. 这有个现象,用stmp 发邮件的时候,即使用异步,也会比较卡(选用的邮件 ...

  5. Go part 6 接口,接口排序,接口嵌套组合,接口与类型转换,接口断言

    接口 接口是一种协议,比如一个汽车的协议,就应该有 “行驶”,“按喇叭”,“开远光” 等功能(方法),这就是实现汽车的协议规范,完成了汽车的协议规范,就实现了汽车的接口,然后使用接口 接口的定义:本身 ...

  6. J.U.C之AQS:阻塞和唤醒线程

    此篇博客所有源码均来自JDK 1.8 在线程获取同步状态时如果获取失败,则加入CLH同步队列,通过通过自旋的方式不断获取同步状态,但是在自旋的过程中则需要判断当前线程是否需要阻塞,其主要方法在acqu ...

  7. QuickJS 快速入门 (QuickJS QuickStart)

    1. QuickJS 快速入门 (QuickJS QuickStart) 1. QuickJS 快速入门 (QuickJS QuickStart) 1.1. 简介 1.2. 安装 1.3. 简单使用 ...

  8. 为满足中国税改,SAP该如何打SPS

    *****一定要先阅读这个note***** ***** 2736625 - [ZH] 应对2019中国个税改革,SAP系统升级常见问题汇总 **** 1784328 - How to check C ...

  9. 十分钟掌握Pandas(上)——来自官网API

    十分钟掌握Pandas(上)——来自官网API 其实不止10分钟,这么多,至少一天 一.numpy和pandas numpy是矩阵计算库,pandas是数据分析库,关于百度百科,有对pandas的介绍 ...

  10. 用js刷剑指offer(二叉树中和为某一值的路径)

    题目描述 输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径.(注意: 在返回值的list中,数组长度大 ...