博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
尼克的任务
阅读量:5225 次
发布时间:2019-06-14

本文共 1222 字,大约阅读时间需要 4 分钟。

这道题虽然很基础但是也不是很好想……

我们一开始会想,用dp[i]表示前i分钟最大休息时间,之后你就完全不知道怎么转移了。

阻碍你转移的关键问题在于,你不知道后面会发生什么,但是如果从后面倒着DP的话就可以了。因为这样的话,你后面的过程相当于是已知的。我们只要在记录一下以这个点为开始的工作有多少,之后直接从那个工作的结束转移过来即可。如果没工作,直接从上一个位置转移即可。

看一下代码。

#include
#include
#include
#include
#include
#include
#include
#define rep(i,a,n) for(int i = a;i <= n;i++)#define per(i,n,a) for(int i = n;i >= a;i--)#define enter putchar('\n')using namespace std;typedef long long ll;const int M = 20005;const int INF = 1000000009;int read(){ int ans = 0,op = 1; char ch = getchar(); while(ch < '0' || ch > '9') { if(ch == '-') op = -1; ch = getchar(); } while(ch >= '0' && ch <= '9') { ans *= 10; ans += ch - '0'; ch = getchar(); } return ans * op;}struct mis{ int p,t; bool operator < (const mis &g) const { return p > g.p; }}a[M];int n,k,sum[M],dp[M],cnt = 1;int main(){ n = read(),k = read(); rep(i,1,k) a[i].p = read(),a[i].t = read(),sum[a[i].p]++; sort(a+1,a+1+k); per(i,n,1) { if(!sum[i]) dp[i] = dp[i+1] + 1; else { rep(j,1,sum[i]) dp[i] = max(dp[i + a[cnt].t],dp[i]),cnt++; } } printf("%d\n",dp[1]); return 0;}

 

转载于:https://www.cnblogs.com/captain1/p/9859353.html

你可能感兴趣的文章
牛人们的博客地址
查看>>
[Codevs] 2492 上帝造题的七分钟2
查看>>
【Java编程思想 - 练习】吸血鬼数字
查看>>
【WP8】同步执行异步代码
查看>>
HDU1945 非常可乐(数论)
查看>>
Codeforces 997B Roman Digits(半打表)
查看>>
[JSOI2008] 火星人prefix
查看>>
POJ-3669
查看>>
/etc/security/limits.conf不生效
查看>>
Swing Jtable 添加checkbox列
查看>>
[Mybatis]Spring与Mybatis整合的MapperScannerConfigurer处理过程源码分析
查看>>
基于“MVC”框架集设计模式,利用 DBHelper实现查询数据库功能
查看>>
PHP 下载文件时自动添加bom头的方法
查看>>
[SPDK/NVMe存储技术分析]009 - Introduction to RDMA Send | RDMA Send操作概论
查看>>
如何登录mysql? cmd怎么连接mysql数据库||从MYSQL客户端登录MYSQL
查看>>
首客记
查看>>
Bower A package manager for the web
查看>>
第六章 ZYNQ-MIZ701 GPIO使用之MIO
查看>>
172322 2018-2019-1 《程序设计与数据结构》实验二报告
查看>>
svn和git
查看>>