样例没过求调
  • 板块P1433 吃奶酪
  • 楼主_Liyx_
  • 当前回复0
  • 已保存回复0
  • 发布时间2024/12/15 21:08
  • 上次更新2024/12/16 13:48:19
查看原帖
样例没过求调
1041884
_Liyx_楼主2024/12/15 21:08
#include<bits/stdc++.h>
using namespace std;
#define N 20
struct node{
	long double x,y;
};
int n;
long double dis[N][N],f[1<<N][N];
node id[N];
int main(){
	memset(f,127,sizeof(f));
	long double ans=f[0][0];
	cin>>n;
	for(int i=1;i<=n;i++) cin>>id[i].x>>id[i].y;
	for(int i=0;i<=n;i++)
		for(int j=i+1;j<=n;j++){
			dis[i][j]=sqrt((id[i].x-id[j].x)*(id[i].x-id[j].x)+(id[i].y-id[j].y)*(id[i].y-id[j].y));
			dis[j][i]=dis[i][j];
		}
	for(int i=1;i<=n;i++) f[1<<(i-1)][i]=dis[0][i];
	for(int k=1;k<(1<<n);k++)
		for(int i=1;i<=n;i++){
			if((k&(1<<(i-1)))==0) continue;
			for(int j=1;j<=n;j++){
				if(i==j) continue;
				if((k&(1<<(j-1)))==0) continue;
				f[k][i]=min(f[k][i],f[k-(1<<(i-1))][j]+dis[i][j]);
			}
		}
	for(int i=1;i<=n;i++){
		ans=min(ans,f[(1<<n)-1][i]);
	}
	printf("%.2lf",ans);
	return 0;
}

真看不出有啥问题了

2024/12/15 21:08
加载中...