CSU 1527 Bounty Hunter dp 双调旅行商

题目链接:点击打开链接

裸的双调旅行商问题啦

#include <stdio.h>#include <string.h>#include <iostream>#include <math.h>#include <queue>#include <set>#include <algorithm>#include <stdlib.h>using namespace std;#define ll int#define N 550#define inf 1152921504606846976struct node{double x, y;bool operator<(const node&a)const{if(a.x==x)return a.y>y;return a.x>x;}void put(){printf("(%.0f, %.0f)\n", x, y);}}p[N];double Dis(node a, node b){return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));}int n;double dis[N][N],dp[N][N];int main(){ll i, j, u, v; int T; scanf("%d", &T);while(T–>0){scanf("%d", &n);for(i=1;i<=n;i++)scanf("%lf %lf",&p[i].x,&p[i].y);sort(p+1,p+n+1);//for(int i = 1; i <= n; i++)p[i].put();for(i=1;i<=n;i++)for(j=1;j<=n;j++)dis[i][j] = Dis(p[i],p[j]), dp[i][j] = inf;dp[1][1] = 0;for(i=2;i<=n;i++){for(j = 1;j < i; j++){dp[i][j] = min(dp[i-1][j]+dis[i][i-1], dp[i][j]);dp[i][i-1] = min(dp[i-1][j]+dis[j][i], dp[i][i-1]);}}printf("%.10f\n",dp[n][n-1]+dis[n][n-1]);}return 0;}

,收敛自己的脾气,偶尔要刻意沉默,

CSU 1527 Bounty Hunter dp 双调旅行商

相关文章:

你感兴趣的文章:

标签云: