K. Road Widening

Posted iss-ue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了K. Road Widening相关的知识,希望对你有一定的参考价值。

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

(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的主要内容,如果未能解决你的问题,请参考以下文章

K. 类型相关的函数

Codeforces K. Ice Skating(求强连通分量)

Swift 2.0将1000格式化为友好的K.

974. Subarray Sums Divisible by K. 前缀和同余定理

974. Subarray Sums Divisible by K. 前缀和同余定理

2018ICPC南京K. Kangaroo Puzzle