2022春每日一题:Day 19

题目:吃奶酪

状压dp实现,dp[i][j]表示走过状态i,停到了j的位置的最小价值。枚举状态,起点终点,转移dp[i][j]=min{dp[i-(1<<s)][k]+dis(s,k)} 其中(s!=k,dis(s,k)表示s和k的欧几里得距离)。
时间复杂度O(n2*2n),跑的还算快。

代码:

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
int n;
double x[16],y[16],dp[1<<16][16];
double get(int a,int b)
{
	return sqrt((x[a]-x[b])*(x[a]-x[b])+(y[a]-y[b])*(y[a]-y[b]));
}
int main()
{
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	    scanf("%lf %lf",&x[i],&y[i]);
	++n;
	for(int i=0;i<(1<<n);i++)
	    for(int j=0;j<n;j++)
	        dp[i][j]=1e5;
	dp[1][0]=0;
	for(int i=0;i<(1<<n);i++)
		for(int j=0;j<n;j++)
		    if(i>>j&1)
		        for(int k=0;k<n;k++)
		            if((i-(1<<j)>>k)&1)
		                dp[i][j]=min(dp[i][j],dp[i-(1<<j)][k]+get(j,k));
	double ret=1e4;
	for(int i=0;i<n;i++)
	    ret=min(ret,dp[(1<<n)-1][i]);
	printf("%.2lf\n",ret);
	return 0;
}
posted @   __honey  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示