题解
2023-03-18 18:00:27
发布于:上海
44阅读
0回复
0点赞
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1e4+9;
pair<int,int> a[maxn];
int dp[maxn];
int main()
{
int T,n;
cin>>T>>n;
memset(dp,-0x3f,sizeof(dp));
for(int i=1;i<=n;++i){
int A,W;
cin>>A>>W;
a[i].first=A,a[i].second=a[i].first+W-1;
}
sort(a+1,a+1+n);
int id=1;
while(id<=n&&a[id].first==a[1].first){
dp[id]=a[1].first-1;
id++;
}
for(int i=id;i<=n;i++){
int ma=0;
for(int j=i-1;j>=1;j--){
if(ma<=a[j].second&&a[i].first>a[j].second) dp[i]=max(dp[j]+a[i].first-a[j].second-1,dp[i]);
if(a[j].first!=a[i].first) ma=max(ma,a[j].first);
}
}
int ans=0;
for(int i=1;i<=n;i++){
if(a[i].second>=a[n].first) ans=max(ans,dp[i]+T-a[i].second);
}
cout<<ans;
return 0;
}
这里空空如也
有帮助,赞一个