P3842 [TJOI2007]线段

Posted sfwr-you

tags:

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

技术图片

 

 


憨憨DP


#include<bits/stdc++.h>
using namespace std;
int n,a[20100],b[20100],f[20100][5];
int calc(int l,int r){return abs(l-r);}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)cin>>a[i]>>b[i];
    f[1][0]=calc(1,b[1])+calc(b[1],a[1]);
    f[1][1]=calc(1,b[1]);
    for(int i=2;i<=n;i++)
    {
    f[i][0]=min(f[i-1][1]+calc(b[i-1],b[i])+calc(a[i],b[i]),f[i-1][0]+calc(b[i],a[i-1])+calc(a[i],b[i]))+1;
    f[i][1]=min(f[i-1][1]+calc(b[i-1],a[i])+calc(a[i],b[i]),f[i-1][0]+calc(a[i],a[i-1])+calc(a[i],b[i]))+1;
    }
    cout<<min(f[n][1]+calc(b[n],n),f[n][0]+calc(a[n],n));
}

 

以上是关于P3842 [TJOI2007]线段的主要内容,如果未能解决你的问题,请参考以下文章

TJOI2007 线段

[TJOI2007] 线段 (动态规划)

Copy自某谷题解[TJOI2007]线段

[TJOI2007]segment

BZOJ5334 [TJOI2018] 数学计算 线段树分治

[TJOI2007]小朋友