多米诺骨牌-SSL 1632

Description 




Input 

  输入文件的第一行是一个正整数n(1≤n≤1000),表示多米诺骨牌数。接下来的n行表示n个多米诺骨牌的点数。每行有两个用空格隔开的正整数,表示多米诺骨牌上下方块中的点数a和b,且1a,b≤6。

Output 

  输出文件仅一行,包含一个整数。表示求得的最小旋转次数。

Sample Input 


4                       
6 1
1 5
1 3
1 2


Sample Output 


1

题解:这道题用dp,f[i]表示最小的旋转速度。
      if f[i]<>f[-10000] then break;  
        if f[-i]<>f[-10000] then break; 

var f:array[-10000..10000] of longint;  
        n,i,j,sum,suma,sumb:longint;  
        a,b:array[1..1000] of longint;  

function min(a,b:longint):longint;  
begin  
   if a<b then exit(a)  
    else exit(b);  
end;  
begin  
  readln(n);  
  for i:=1 to n do readln(a[i],b[i]);  
  for i:=1 to n do suma:=suma+a[i];  
   for i:=1 to n do sumb:=sumb+b[i];  
   for i:=1 to n do sum:=sum+a[i]+b[i]-min(a[i],b[i]);  
   fillchar(f,sizeof(f),127);  
   f[suma-sumb]:=0;  
   for i:=1 to n do 
    begin  
      if a[i]>b[i] then  
      for j:=-sum to sum do  
      f[j]:=min(f[j],f[j+2*(a[i]-b[i])]+1);   
     if a[i]<b[i] then  
     for j:=sum downto -sum do  
     f[j]:=min(f[j],f[j+2*(a[i]-b[i])]+1);  
    end;  
    for i:=0 to sum do 
     begin  
        if f[i]<>f[-10000] then break;  
        if f[-i]<>f[-10000] then break;  
     end;  
     writeln(min(f[i],f[-i]));  
end.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值