码迷,mamicode.com
首页 > 其他好文 > 详细

K. Road Widening

时间:2020-05-05 17:48:05      阅读:43      评论:0      收藏:0      [点我收藏+]

标签:else   lin   bit   ace   --   lan   name   lse   区间   

\(考虑每个区域可行的区间\)

\(x[1]=s[1]\ \ y[1]=s[1]+g[1]\)

\(x[i]=max(x[i-1]-1,s[i]),y[i]=min(y[i-1]+1,s[i]+g[i])\)

\(然后这样能确保每一个区间都满足前面的区间,但不意味前面的区间满足后面的区间\)

\(倒过来也做一次,之后对每个都取y[i]\)

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=2000005;
ll x[maxn],y[maxn],s[maxn],g[maxn],flag=1;
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)	cin>>s[i]>>g[i];
	x[1]=s[1],y[1]=s[1]+g[1];
	for(int i=2;i<=n;i++)
	{
		x[i]=max(x[i-1]-1,s[i]);
		y[i]=min(y[i-1]+1,s[i]+g[i]);
		if(x[i]>y[i])	flag=0;
	}
	for(int i=n-1;i>=1;i--)
	{
		x[i]=max(x[i+1]-1,x[i]);
		y[i]=min(y[i+1]+1,y[i]);
		if(x[i]>y[i])	flag=0;
	}
	ll ans=0;
	for(int i=1;i<=n;i++)	ans+=y[i]-s[i];
	if(flag==0)	cout<<-1;
	else
	{
		cout<<ans<<endl;
		for(int i=1;i<=n;i++)	cout<<y[i]<<" ";
	}
}

K. Road Widening

标签:else   lin   bit   ace   --   lan   name   lse   区间   

原文地址:https://www.cnblogs.com/iss-ue/p/12831393.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!