社区讨论
求调 过样例 全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 条回复,欢迎继续交流。
正在加载回复...