主题链接:

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. openGL研究钞四 : 关于颜色, 尺寸, 虚线, 多边形逆转, 空洞, 使用位图

    转载请保留源,,,,hushuai1992http://blog.csdn.net/u013642494/article/category/2675731 额. 这个标题我都不知道该怎么起了. 假设没 ...

  2. 在JBuilder8在使用ANT

    在JBuilder8中使用ANT                                                            作者:翁驰原    在JBuilder8中.Ap ...

  3. DSR on Openstack POC

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbWFvbGlwaW5nNDU1bWxwNDU1/font/5a6L5L2T/fontsize/400/fil ...

  4. 静态常量(static final)在class文件里是如何的呢?

    近期写项目遇到一个问题,来回折腾了几次,最终探究清楚了.不废话.上样例. 背景:由于项目小,没有使用配置文件,全部静态常量都放在Config.java里面了 public class Config { ...

  5. [精华]Hadoop,HBase分布式集群和solr环境搭建

    1. 机器准备(这里做測试用,目的准备5台CentOS的linux系统) 1.1 准备了2台机器,安装win7系统(64位) 两台windows物理主机: 192.168.131.44 adminis ...

  6. ListView 实现多选/无线电

    ListView本身与无线电.多选模式.由listview.setChoiceMode设置: listview.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE) ...

  7. C# - is

     Checks if an object is compatible with a given type. An is expression evaluates to true if the pr ...

  8. Objective-C辛格尔顿

    单例类是一种特殊的类.在一个进程种仅仅会存在一个该类的对象,在iOS应用中仅仅会出现一个对象.这样的设计模式在系统框架中很多地方都使用了.如NSFileManager.UIApplication等. ...

  9. HDU 1518 Square 搜索

    Problem Description Given a set of sticks of various lengths, is it possible to join them end-to-end ...

  10. aauto攫http数据

    说明:灵巧使用上述数据的抓取网页简单的例子. 样例:想把某站点的数据抓回来.然后保存在数据库里边. 步骤:1.打开sql.new一个数据库Test.新建一个表test. 2.打开快手.准备抓数据,以这 ...