出自附中练习场【难度C】—————————————————————————————————————————————————————————————

【试题描述】有 N 个任务, 每个任务最多只能完成一次。另外,每个任务都有两个属性 c[i]、 d[i]。 c[i]的意思是第 i 个任务必须要在第 c[i]个单位时间或之前完成。完成第 i 个任务所需要的时间为 d[i]。 初始时 0 时刻。 求最多能完成几个任务。

【输入】第一行: N
           接下来 N 行, d[i], c[i]

【输出】最多能完成的任务。

【输入样例】

4
100 200
200 1300
1000 1250
2000 3200

【输出样例】

3

【解题思路】典型贪心算法,我们称完成时间为t1,我们现在对t1进行排序,得到(样例:100 200 1000 2000)现在,我们可以建一个heap了(类似于队列),对于每一项任务,分两种大操作:插入或不插入,不插入又分两种,不做某项任务或把其他任务删除,更新为现在的任务。那么有几种触发条件1、如果当前大于等于最大,不插入2、如果小于,那就更新或插入。

【代码在地下200m】

——————————————————————————————————100m————————————————————————————————-———

——————————————————————————————————200m————————————————————————————————————

#include <iostream>
#include <cstring>
#include <queue>
#include <cstdio>
#include <algorithm> using namespace std; const int N=150005; struct Heap
{
int A[N<<1|1], tot; void init(int n)
{
for(int i=1; i<=(n<<1|1); i++) A[i]=0;
tot=0;
} void Insert(int val)
{
A[++tot]=val;
for(int x=tot; x>1 && A[x]>A[x>>1]; x>>=1) swap(A[x], A[x>>1]);
} void Update(int val)
{
A[1]=val;
for(int i=1, j=2; j<=tot; i=j, j<<=1)
{
if((j|1)<=tot && A[j]<A[j|1]) j|=1;
if(A[j]<A[i]) break;
swap(A[i], A[j]);
}
}
} heap; struct data
{
int t1, t2;
bool operator < (const data &T) const
{
return t2<T.t2;
}
} A[N];
int n, ans, cur; int main()
{
while(scanf("%d", &n)!=EOF)
{
for(int i=0; i<n; i++) scanf("%d%d", &A[i].t1, &A[i].t2);
sort(A, A+n);
cur=ans=0, heap.init(n);
for(int i=0; i<n; i++)
{
if(A[i].t1+cur<=A[i].t2) ans++, heap.Insert(A[i].t1), cur+=A[i].t1;
else
{
if(!heap.tot) continue;
int val=heap.A[1];
if(val<=A[i].t1) continue;
cur-=val-A[i].t1;
heap.Update(A[i].t1);
}
}
printf("%d\n", ans);
}
//sysytem("pause");
return 0;
}

  

DAY7L2【C001】的更多相关文章

  1. 【C-001】printf理解

    输出整型的数值就不说了, 显示浮点型: printf("%.2f",3.33); //保留两位小数显示,数字前面没有空格填充 显示的时候,设计到0-1之间的数的时候: printf ...

  2. 【BIEE】04_当维度表中的维不存在事实表中,需要展示所有维度并且数据类展示为0

    有时候,我们往往会存在这样的需求 例如:事实表的数据如下 EMP_FACT表示事实表,DIM_LEVEL是维度表 预期效果:(根据员工信息,分析各等级员工工资与员工个数) 我们在BIEE报表中新建报表 ...

  3. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  4. 【原】谈谈对Objective-C中代理模式的误解

    [原]谈谈对Objective-C中代理模式的误解 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 这篇文章主要是对代理模式和委托模式进行了对比,个人认为Objective ...

  5. 【原】FMDB源码阅读(三)

    [原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...

  6. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  7. 【调侃】IOC前世今生

    前些天,参与了公司内部小组的一次技术交流,主要是针对<IOC与AOP>,本着学而时习之的态度及积极分享的精神,我就结合一个小故事来初浅地剖析一下我眼中的“IOC前世今生”,以方便初学者能更 ...

  8. Python高手之路【三】python基础之函数

    基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...

  9. Python高手之路【一】初识python

    Python简介 1:Python的创始人 Python (英国发音:/ˈpaɪθən/ 美国发音:/ˈpaɪθɑːn/), 是一种解释型.面向对象.动态数据类型的高级程序设计语言,由荷兰人Guido ...

随机推荐

  1. 一次工作中用到的Highcharts.Chart

    一般动态获取图表信息都是通过ajax交互传送数据. 这次是一次性从后台返回集合后,直接在页面取数据绘制图表 引用js <script type="text/javascript&quo ...

  2. GCD的使用

    什么是 GCD Grand Central Dispatch (GCD) 是 Apple 开发的一个多核编程的解决方法.该方法在 Mac OS X 10.6 雪豹中首次推出,并随后被引入到了 iOS4 ...

  3. C++静态代码分析PreFast

    1历史 Prefast是微软研究院提出的静态代码分析工具.主要目的是通过分析代码的数据和控制信息来检测程序中的缺陷.需要强调的是,Prefast检测的缺项不仅仅是安全缺陷,但是安全缺陷类型是其检测的最 ...

  4. 方法重载的小demo

    方法的重载(overload)要求:1,同一个类中2,方法名必须相同3,方法的参数列表不同(1,参数的个数不同2,参数类型不同,但是参数名相同) 注:方法的重载与方法的返回值类型没有关系 packag ...

  5. UINavigationController导航条是否挡住下面的内容

    控制 UINavigationController 导航条是否挡住下面的内容 if ([[[UIDevice currentDevice] systemVersion] floatValue] > ...

  6. springmvc注解配置

    <?xml version="1.0" encoding="UTF-8" ?> <beans xmlns="http://www.s ...

  7. bnuoj 24251 Counting Pair

    一道简单的规律题,画出二维表将数字分别相加可以发现很明显的对称性 题目链接:http://www.bnuoj.com/v3/problem_show.php?pid=24251 #include< ...

  8. JAVA数据库基本操作 (转)

    JAVA数据库基本操作指南   Java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接. 一.取得数据库连接 1.用DriverManager取数据库连接 ...

  9. MVC – 4.mvc初体验(1)

    1.MVC请求模式   2.MVC简单请求流程图 展开 折叠     3.返回string的mvc方法 展开 折叠   4.加载视图的方法  

  10. Java内存泄露的理解与解决

    依赖于引用判断的内存管理机制 Java中对内存对象的访问,使用的是引用的方式.在Java代码中我们维护一个内存对象的引用变量,通过这个引用变量的值,我们可以访问到对应的内存地址中的内存对象空间.在Ja ...