最优配对问题

传送门

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.
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值