2022春每日一题:Day 19


题目:吃奶酪

状压dp实现,dp[i][j]表示走过状态i,停到了j的位置的最小价值。枚举状态,起点终点,转移dp[i][j]=min{dp[i-(1< 时间复杂度O(n2*2n),跑的还算快。

代码:

#include 
#include 
#include 
#include 
#include 
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<>j&1)
		        for(int k=0;k>k)&1)
		                dp[i][j]=min(dp[i][j],dp[i-(1<