社区讨论

求调 过样例 全WA 码风不好看

P3842[TJOI2007] 线段参与者 1已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@lwvz07tg
此快照首次捕获于
2024/06/01 18:28
2 年前
此快照最后确认于
2024/06/01 20:48
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n, l[20010], r[20010], f[20010][3];
int dfs(int x, int z) {
    if (x == 1)
        f[x][z] = z ? r[x] : l[x];
    if (f[x][z])
        return f[x][z];
    f[x][z] = 1000000000;
    for (int last = 0; last <= 1; ++last) {
        dfs(x - 1, last);
        f[x][z] = min(f[x][z], abs((z ? r[x] : l[x]) - (last ? r[x - 1] : l[x - 1]) + r[x] - l[x] + 1) + 1 + f[x - 1][last]); 
    }
    //cout << "I'm here! " << x << " " << f[x][z] << "\n"; 
    return f[x][z];
}
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    cin >> n;
    for (int i = 1; i <= n; ++i) {
        cin >> l[i] >> r[i];
    }
    cout << min(dfs(n, 0) + n - l[n], dfs(n, 1) + n - r[n]); 

    return 0;
}
不胜感激。祝您rp++。

回复

1 条回复,欢迎继续交流。

正在加载回复...