poj1166

#include <iostream>

using namespace std;

int main()
{
      int i,a[10],b[10],c[10];
      for(i=1;i<=9;i++) cin>>a[i];
      for(b[1]=0;b[1]<=3;b[1]++)   /*每个钟最多转三次,四次则等于没转,4的9次方钟可能,同理,翻棋子,按开关等每个最多操作一次 ,用BFS会超时!*/
      for(b[2]=0;b[2]<=3;b[2]++)
      for(b[3]=0;b[3]<=3;b[3]++)
      for(b[4]=0;b[4]<=3;b[4]++)
      for(b[5]=0;b[5]<=3;b[5]++)
      for(b[6]=0;b[6]<=3;b[6]++)
      for(b[7]=0;b[7]<=3;b[7]++)
      for(b[8]=0;b[8]<=3;b[8]++)
      for(b[9]=0;b[9]<=3;b[9]++)
      {
            c[1]=(a[1]+b[1]+b[2]+b[4])%4;
            c[2]=(a[2]+b[1]+b[2]+b[3]+b[5])%4;
            c[3]=(a[3]+b[2]+b[3]+b[6])%4;
            c[4]=(a[4]+b[1]+b[4]+b[5]+b[7])%4;
            c[5]=(a[5]+b[1]+b[3]+b[5]+b[7]+b[9])%4;
            c[6]=(a[6]+b[3]+b[5]+b[6]+b[9])%4;
            c[7]=(a[7]+b[4]+b[7]+b[8])%4;
            c[8]=(a[8]+b[5]+b[7]+b[8]+b[9])%4;
            c[9]=(a[9]+b[6]+b[8]+b[9])%4;
            if(c[1]+c[2]+c[3]+c[4]+c[5]+c[6]+c[7]+c[8]+c[9]==0)
            {
                    for(i=0;i<b[1];i++) cout<<"1 ";
                    for(i=0;i<b[2];i++) cout<<"2 ";
                    for(i=0;i<b[3];i++) cout<<"3 ";
                    for(i=0;i<b[4];i++) cout<<"4 ";
                    for(i=0;i<b[5];i++) cout<<"5 ";
                    for(i=0;i<b[6];i++) cout<<"6 ";
                    for(i=0;i<b[7];i++) cout<<"7 ";
                    for(i=0;i<b[8];i++) cout<<"8 ";
                    for(i=0;i<b[9];i++) cout<<"9 ";
                    cout<<endl;
                    return 0;
            }
      }
}
有9个时钟,排成一个3*3的矩阵。

现在需要用最少的移动,将9个时钟的指针都拨到12点的位置。共允许有9种不同的移动。如右表所示,每个移动会将若干个时钟的指针沿顺时针方向拨动90度。

移动 影响的时钟
1 ABDE
2 ABC
3 BCEF
4 ADG
5 BDEFH
6 CFI
7 DEGH
8 GHI
9 EFHI
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值