社区讨论
求助,Wa了三个,感觉思路没啥问题啊
P1220关路灯参与者 2已保存回复 1
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 1 条
- 当前快照
- 1 份
- 快照标识符
- @lo8r477d
- 此快照首次捕获于
- 2023/10/27 23:11 2 年前
- 此快照最后确认于
- 2023/10/27 23:11 2 年前
CPP
#include<iostream>
#include<algorithm>
#include<string.h>
#include<math.h>
using namespace std;
const int maxn=55;
int f[maxn][maxn][maxn];
int g[maxn][maxn][maxn];
int g1[maxn][maxn][maxn];
int d[maxn],W[maxn];
void init(){
for(int i=1;i<maxn;i++){
for(int j=1;j<maxn;j++){
for(int k=1;k<maxn;k++){
f[i][j][k]=1e9;
}
}
}
}
int main(){
init();
int n,st;
cin>>n>>st;
for(int i=1;i<=n;i++)cin>>d[i]>>W[i];
f[st][st][st]=0;
for(int len=2;len<=n;len++){
for(int i=1;i+len-1<=n;i++){
int j=i+len-1;
for(int k=i+1;k<=j;k++){
g[i][j][i]=g1[i+1][j][k]+abs(d[k]-d[i]);
if(f[i][j][i]>f[i+1][j][k]+g[i][j][i]*W[i]){
f[i][j][i]=f[i+1][j][k]+g[i][j][i]*W[i];
g1[i][j][i]=g[i][j][i];
}
}
for(int k=i;k<=j-1;k++){
g[i][j][j]=g1[i][j-1][k]+abs(d[k]-d[j]);
if(f[i][j][j]>f[i][j-1][k]+g[i][j][j]*W[j]){
f[i][j][j]=f[i][j-1][k]+g[i][j][j]*W[j];
g1[i][j][j]=g[i][j][j];
}
}
}
}
cout<<min(f[1][n][1],f[1][n][n]);
return 0;
}
思路就是从i到j的最小一定是i到j内没有灯了,否则一定还有比他小的,所以只考虑了f[i][j][i]和f[i][j][j],f是i到j全关闭并且最后是k的情况。大佬们求助
回复
共 1 条回复,欢迎继续交流。
正在加载回复...