Luogu P4053 [JSOI2007]建筑抢修
时间:2019-11-11
本文章向大家介绍Luogu P4053 [JSOI2007]建筑抢修,主要包括Luogu P4053 [JSOI2007]建筑抢修使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题目
贪心。
首先我们把所有建筑按\(ddl\)升序排序。
然后从前往后枚举每个建筑,如果当前能够修它就直接修。
如果不能直接修的话我们再看把之前修的中修复时间最长的那个去掉之后能不能修这个,如果可以就不修那个时间最长的了,改修当前这个。
口胡一下正确性:
进行第二个操作不会改变当前修了的总数。
而且如果把之间修复时间最长的那个去掉之后能够修现在这个,说明现在这个的修复时间一定比之前那个短,替换一下会让修完这个的时间更短。
因此我们在不降低答案的情况下让修的时间更短了,这个肯定是更优的。
#include<bits/stdc++.h>
#define ll long long
using namespace std;
int read(){int x=0,c=getchar();while(!isdigit(c))c=getchar();while(isdigit(c))x=x*10+c-48,c=getchar();return x;}
const int N=150007;
struct node{int t,ed;}a[N];
int operator<(node a,node b){return a.ed<b.ed;}
priority_queue<int>q;
int main()
{
int n=read(),i,ans=0;ll t=0;
for(i=1;i<=n;++i) a[i]=(node){read(),read()};
sort(a+1,a+n+1);
for(i=1;i<=n;++i)
if(t+a[i].t<=a[i].ed) ++ans,q.push(a[i].t),t+=a[i].t;
else if(q.top()>a[i].t&&t+a[i].t-q.top()<a[i].ed) t+=a[i].t-q.top(),q.pop(),q.push(a[i].t);
printf("%d",ans);
}
原文地址:https://www.cnblogs.com/cjoierShiina-Mashiro/p/11837921.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- laravel5环境隐藏index.php后缀(apache)的方法
- php实现对文件压缩简单的方法
- laravel实现Auth认证,登录、注册后的页面回跳方法
- php 实现银联商务H5支付的示例代码
- Yii2.0框架behaviors方法使用实例分析
- laravel 去掉index.php伪静态的操作方法
- laravel 获取某个查询的查询SQL语句方法
- laravel dingo API返回自定义错误信息的实例
- Linux基于php-fpm模式的lamp搭建phpmyadmin的办法
- 基于laravel Request的所有方法详解
- 浅谈thinkphp的nginx配置,以及重写隐藏index.php入口文件方法
- php图片裁剪函数
- Laravel自定义 封装便捷返回Json数据格式的引用方法
- Laravel模糊查询区分大小写的实例
- laravel实现一个上传图片的接口,并建立软链接,访问图片的方法