主题链接:

pid=1881">http://acm.hdu.edu.cn/showproblem.php?

pid=1881

----------------------------------------------------------------------------------------------------------------------------------------------------------
欢迎光临天资小屋http://user.qzone.qq.com/593830943/main

----------------------------------------------------------------------------------------------------------------------------------------------------------

Problem Description
每年毕业的季节都会有大量毕业生发起狂欢。好朋友们相约吃散伙饭。网络上称为“bg”。

參加不同团体的bg会有不同的感觉,我们能够用一个非负整数为每一个bg定义一个“快乐度”。现给定一个bg列表,上面列出每一个bg的快乐度、持续长度、bg发起人的离校时间。请你安排一系列bg的时间使得自己能够获得最大的快乐度。



比如有4场bg:

第1场快乐度为5。持续1小时,发起人必须在1小时后离开;

第2场快乐度为10,持续2小时,发起人必须在3小时后离开;

第3场快乐度为6。持续1小时,发起人必须在2小时后离开;

第4场快乐度为3。持续1小时,发起人必须在1小时后离开。

则获得最大快乐度的安排应该是:先開始第3场,获得快乐度6。在第1小时结束,发起人也来得及离开;再開始第2场,获得快乐度10。在第3小时结束。发起人正好来得及离开。

此时已经无法再安排其它的bg,由于发起人都已经离开了学校。因此获得的最大快乐度为16。



注意bg必须在发起人离开前结束,你不能够中途离开一场bg,也不能够中途增加一场bg。

又由于你的人缘太好。可能有多达30个团体bg你,所以你须要写个程序来解决这个时间安排的问题。

 
Input
測试输入包括若干測试用例。每一个測试用例的第1行包括一个整数N (<=30)。随后有N行。每行给出一场bg的信息:

h l t

当中 h 是快乐度。l是持续时间(小时)。t是发起人离校时间。数据保证l不大于t,由于若发起人必须在t小时后离开,bg必须在主人离开前结束。



当N为负数时输入结束。
 
Output
每一个測试用例的输出占一行。输出最大快乐度。

 
Sample Input
3
6 3 3
3 2 2
4 1 3
4
5 1 1
10 2 3
6 1 2
3 1 1
-1
 
Sample Output
7
16

代码例如以下:

#include <iostream>
#include <algorithm>
using namespace std;
int n, ans;
struct bg
{
int h, l, t;
}a[32];
bool cmp(bg a, bg b)
{
return a.t < b.t;
}
void dfs(int i, int hh, int tt)
{
if(i == n)
{
if(hh > ans)
ans = hh;
return;
}
if(tt+a[i].l <= a[i].t)
{
dfs(i+1,hh+a[i].h,a[i].l+tt);
}
dfs(i+1,hh,tt);
return;
}
int main()
{
while(cin>>n)
{
if(n < 0)
break;
ans = 0;
for(int i = 0; i < n; i++)
{
cin>>a[i].h>>a[i].l>>a[i].t;
}
sort(a,a+n,cmp);
dfs(0,0,0);
cout<<ans<<endl;
}
return 0;
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

hdu1881 毕业bg(深搜索dfs)的更多相关文章

  1. HDU-1881 毕业bg (01背包变形)

    毕业bg Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...

  2. 毕业bg(dfs)

    毕业bg Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submissi ...

  3. 简单搜索dfs, 简单的修剪搜索

    选择最合适的语言做一个项目是非常重要的.但,熟练的掌握自己的武器,这也是非常重要的. ========================================================= ...

  4. 深度优先搜索DFS和广度优先搜索BFS简单解析(新手向)

    深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每个点仅被访问一次,这个过程就是图的遍历.图的遍历常用的有深度优先搜索和广度优先搜索,这两者对于有向图和无向图 ...

  5. 利用广度优先搜索(BFS)与深度优先搜索(DFS)实现岛屿个数的问题(java)

    需要说明一点,要成功运行本贴代码,需要重新复制我第一篇随笔<简单的循环队列>代码(版本有更新). 进入今天的主题. 今天这篇文章主要探讨广度优先搜索(BFS)结合队列和深度优先搜索(DFS ...

  6. 深度优先搜索DFS和广度优先搜索BFS简单解析

    转自:https://www.cnblogs.com/FZfangzheng/p/8529132.html 深度优先搜索DFS和广度优先搜索BFS简单解析 与树的遍历类似,图的遍历要求从某一点出发,每 ...

  7. 【算法入门】深度优先搜索(DFS)

    深度优先搜索(DFS) [算法入门] 1.前言深度优先搜索(缩写DFS)有点类似广度优先搜索,也是对一个连通图进行遍历的算法.它的思想是从一个顶点V0开始,沿着一条路一直走到底,如果发现不能到达目标解 ...

  8. 深度优先搜索 DFS 学习笔记

    深度优先搜索 学习笔记 引入 深度优先搜索 DFS 是图论中最基础,最重要的算法之一.DFS 是一种盲目搜寻法,也就是在每个点 \(u\) 上,任选一条边 DFS,直到回溯到 \(u\) 时才选择别的 ...

  9. POJ 2243 简单搜索 (DFS BFS A*)

    题目大意:国际象棋给你一个起点和一个终点,按骑士的走法,从起点到终点的最少移动多少次. 求最少明显用bfs,下面给出三种搜索算法程序: // BFS #include<cstdio> #i ...

随机推荐

  1. Vim设置colorscheme小技巧

    Vim的颜色主题在/usr/share/vim/vim73/colors目录里.打开vim后在normal模式下输入":colorscheme"查看当前的主题,改动主题使用命令&q ...

  2. Reveal:分析iOS UI该武器

    Reveal是分析iOS应用UI的利器: Reveal可以在执行时调试和改动iOS应用程序.它能连接到应用程序,并同意开发人员编辑各种用户界面參数.这反过来会马上反应在程序的UI上.就像用FireBu ...

  3. python获取的信息列表微信公共平台和用户头像

    转载注明原文地址:http://blog.csdn.net/btyh17mxy/article/details/25207889 只写模拟登陆的方式获取微信从信息和头像库列表公共平台, - 相关后,功 ...

  4. 解决linux看温度是报错No sensors found问题

    今日因为同事的linuxserver频繁死机,其型号和配置与我的一致,故此与其对照了一下server的内存使用率.CPU使用率.温度等信息. 在对照温度信息的时候发现无法使用sensors进行温度查看 ...

  5. JCombox

    A component that combines a button or editable field and a drop-down list. The user can select a val ...

  6. iOS_动态插入或删除行

    终于效果图: 分MVC三层设计;自己定义的Cell有两种;一种是MainCell,由ModelArr提供数据源;还有一种是插入的cell,由代码创建,而且由另外一个数组供状态数据 数据源部分: wat ...

  7. Source insight 3572安装和版本号An invalid source insight serial number was detected解

    Source insight最新版本3572 下载链接:http://www.sourceinsight.com/down35.html,   http://www.sourceinsight.com ...

  8. 8、Cocos2dx 3.0三,找一个小游戏开发3.0存储器管理的版本号

    重开发人员的劳动成果,转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/27693365 复杂的内存管理 移动设备上的硬件资源十 ...

  9. 页面中插入百度地图(使用百度地图API)

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWF5dW4wNTE2/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...

  10. 8年,属于 HTML 5 春天的到来悄悄!

    [核心提示] 在 8 年时间中,HTML 5 为整个行业都带来了什么.标准终于确定后又会产生什么样的变革呢? 微博微信Twitter对于非常多人来说,非常有可能在微信的朋友圈里玩过「围住神经猫」,也非 ...