传送门
http://218.62.22.209:8080/problem.php?id=1288
题解
dp[i]:i表示匹配的状态,1表示已匹配,0表示为匹配
dp[i]由那些状态转移过来?
我们枚举i中已配对的两个,把他们变成0就得到了转移状态
O(n22n)
我们枚举时会有重复的,因为它其实只是个组合问题,没有选的顺序,所以先选后选其实都可以,所以我们确定枚举的两个点中一个一定为第一个1,再枚举另一个就可以
O(n2n)
var
dp:array[0..1100000]of real;
x:array[0..100,1..2]of longint;
i,j,k:longint;
n,t:longint;
function odd(a:longint):longint;
begin
a:=a xor(a>>1);
a:=a xor(a>>2);
a:=a xor(a>>4);
a:=a xor(a>>8);
a:=a xor(a>>16);
exit(a and 1);
end;
function min(a,b:real):real;
begin
if a<b then exit(a) else exit(b);
end;
function dis(a,b:longint):real;
begin
exit(sqrt((x[a,1]-x[b,1])*(x[a,1]-x[b,1])+(x[a,2]-x[b,2])*(x[a,2]-x[b,2])));
end;
begin
readln(n);
for i:=1 to n do
readln(x[i,1],x[i,2]);
dp[0]:=0;
for i:=1 to 1<<n-1 do
begin
if odd(i)=1 then continue;
dp[i]:=1000000000;
for j:=1 to n-1 do
if i and (1<<(j-1))<>0
then break;
for k:=j+1 to n do
if i and (1<<(k-1))<>0
then dp[i]:=min(dp[i],dp[i-1<<(j-1)-1<<(k-1)]+dis(j,k));
end;
writeln(dp[1<<n-1]:0:2);
end.