HDOJ4864:Task

题意:

给出n个机器和m个任务,对于一天来说,每个机器有最大工作时间xi,可接受最大等级yi,每个任务有一个工作时间xi,一个等级yi,可获价值为500*xi+2*yi,任务需要在一台机器一天内完成,问我们一天可得到的最大价值。

思路:

由于xi的系数500远大于yi的系数,故只要使xi最大,总价值一定最大。

所以我们从任务开始贪心而不选择从机器开始贪心,将任务和机器以时间从大到小,相同则使等级从大到小进行排序,然后对于每一个任务,记录工作时间大于它的机器,然后从任务的等级开始往上搜,搜到即记录并跳出,最后输出即可。

推荐blog:

http://blog.csdn.net/a601025382s/article/details/38046927

http://www.cnblogs.com/-sunshine/p/3862810.html

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<algorithm>
 4 using namespace std;
 5 const int maxn=1e5+10;
 6
 7 int n,m,maxx,sum,coun;
 8 struct node
 9 {
10     int time,level;
11     bool operator<(const node& p)const
12     {
13         if(time==p.time) return level>p.level;
14         return time>p.time;
15     }
16 }a[maxn],b[maxn];
17 int c[101];
18
19 int main()
20 {
21     while(scanf("%d%d",&n,&m)==2)
22     {
23         coun=0;
24         __int64 sum=0;
25         for(int i=1;i<=n;i++) {scanf("%d%d",&a[i].time,&a[i].level);}
26         for(int i=1;i<=m;i++) {scanf("%d%d",&b[i].time,&b[i].level);}
27         sort(a+1,a+n+1);sort(b+1,b+m+1);
28         memset(c,0,sizeof(c));
29         //for(int i=1;i<=n;i++) printf("%d %d\n",a[i].time,a[i].level);
30         //for(int i=1;i<=m;i++) printf("%d %d\n",b[i].time,b[i].level);
31         for(int i=1,j=1;i<=m;i++)
32         {
33             while(j<=n&&a[j].time>=b[i].time)//统计>=当前任务时间的机器
34             {
35                 c[a[j].level]++;//记录机器的等级
36                 j++;
37             }
38             for(int k=b[i].level;k<=100;k++)//从当前任务的等级开始
39             {
40                 if(c[k])//找到最小的等级
41                 {
42                     coun++;
43                     c[k]--;
44                     sum+=500*b[i].time+2*b[i].level;
45                     break;
46                 }
47             }
48         }
49         printf("%d %I64d\n",coun,sum);
50     }
51     return 0;
52 }

时间: 2024-08-08 12:47:05

HDOJ4864:Task的相关文章

编写高质量代码改善C#程序的157个建议——建议85:Task中的异常处理

建议85:Task中的异常处理 在任何时候,异常处理都是非常重要的一个环节.多线程与并行编程中尤其是这样.如果不处理这些后台任务中的异常,应用程序将会莫名其妙的退出.处理那些不是主线程(如果是窗体程序,那就是UI主线程)产生的异常,最终的办法都是将其包装到主线程上. 在任务并行库中,如果对任务运行Wait.WaitAny.WaitAll等方法,或者求Result属性,都能捕获到AggregateException异常.可以将AggregateException异常看做是任务并行库编程中最上层的异

Spark源码分析之八:Task运行(二)

在<Spark源码分析之七:Task运行(一)>一文中,我们详细叙述了Task运行的整体流程,最终Task被传输到Executor上,启动一个对应的TaskRunner线程,并且在线程池中被调度执行.继而,我们对TaskRunner的run()方法进行了详细的分析,总结出了其内Task执行的三个主要步骤: Step1:Task及其运行时需要的辅助对象构造,主要包括: 1.当前线程设置上下文类加载器: 2.获取序列化器ser: 3.更新任务状态TaskState: 4.计算垃圾回收时间: 5.反

Spark源码分析之六:Task调度(二)

话说在<Spark源码分析之五:Task调度(一)>一文中,我们对Task调度分析到了DriverEndpoint的makeOffers()方法.这个方法针对接收到的ReviveOffers事件进行处理.代码如下: [java] view plain copy // Make fake resource offers on all executors // 在所有的executors上提供假的资源(抽象的资源,也就是资源的对象信息,我是这么理解的) private def makeOffers

Spark源码分析之七:Task运行(一)

在Task调度相关的两篇文章<Spark源码分析之五:Task调度(一)>与<Spark源码分析之六:Task调度(二)>中,我们大致了解了Task调度相关的主要逻辑,并且在Task调度逻辑的最后,CoarseGrainedSchedulerBackend的内部类DriverEndpoint中的makeOffers()方法的最后,我们通过调用TaskSchedulerImpl的resourceOffers()方法,得到了TaskDescription序列的序列Seq[Seq[Tas

Spark源代码分析之六:Task调度(二)

话说在<Spark源代码分析之五:Task调度(一)>一文中,我们对Task调度分析到了DriverEndpoint的makeOffers()方法.这种方法针对接收到的ReviveOffers事件进行处理.代码例如以下: // Make fake resource offers on all executors     // 在全部的executors上提供假的资源(抽象的资源.也就是资源的对象信息,我是这么理解的)     private def makeOffers() {       /

RTL基本知识:task和function

在使用Verilog进行设计的过程中,使用task和function在同一个module中多次调用,充分提高了代码的复用性,有效增强设计的可维护性和复用性,可以避免不同模块间代码复制导致的不必要的错误.本文主要探讨task和function的使用以及两者之间的异同点. 1    task 定义不能出现在过程性语句快中,但是必须在"module-end"结构中. 格式一: 格式二: task可以没有或者有一个或多个参数,值通过参数传入和传出task.输入输出在任务开始处声明,且输入与输出

[深入学习C#]C#实现多线程的方式:Task——任务

简介 .NET 4包含新名称空间System.Threading.Tasks,它 包含的类抽象出了线程功能. 在后台使用ThreadPool. 任务表示应完成的某个单元的工作. 这个单元的工作可以在单独的线程中运行,也可以以同步方式启动一个任务,这需要等待主调线程. 使用任务不仅可以获得一个抽象层,还可以对底层线程进行很多控制.  在安排需要完成的工作时,任务提供了非常大的灵活性. 例如,可 以定义连续的工 作-- 在一个任务完成后该执行什么工作. 这可以区分任务成功与否. 另外,还可以在层次结

Maintenance Plan Usage3:Task Usage (Maintain Index)

Maintenance Plan用于维护Index Fragmentation 和 Statistics的Task 共有三个,后台是使用相应的TSQL来进行data维护. Reorganize Index Task Move index pages into a more efficient search order. This task uses the ALTER INDEX REORGANIZE statement with SQL Server 2012 databases. Rebui

Spark源码分析之五:Task调度(一)

在前四篇博文中,我们分析了Job提交运行总流程的第一阶段Stage划分与提交,它又被细化为三个分阶段: 1.Job的调度模型与运行反馈: 2.Stage划分: 3.Stage提交:对应TaskSet的生成. Stage划分与提交阶段主要是由DAGScheduler完成的,而DAGScheduler负责Job的逻辑调度,主要职责也即DAG图的分解,按照RDD间是否为shuffle dependency,将整个Job划分为一个个stage,并将每个stage转化为tasks的集合--TaskSet.