社区讨论

求助,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 条回复,欢迎继续交流。

正在加载回复...