USACO1.4 The Clocks(clocks)

        使用暴力搜索,枚举所有移动方案,及时中止不合时方案来节省时间。到现在依旧不会使用更高级的搜索算法,下一步需要学习一下理论知识。

 

/*
ID:jzzlee1
PROG:clocks
LANG:C++
*/
#include<iostream>
#include<fstream>
#include<cstring>
#include<cctype>
#include<cstdio>
using namespace std;
ifstream fin("clocks.in");
ofstream fout("clocks.out");
int a[10],s=0,m=1000000,c[10],d[10],e[10];
//b[][]保存9种移动方法,每移一次加1
int b[10][10]={
	{0,0,0,0,0,0,0,0,0,0},
	{0,1,1,0,1,1,0,0,0,0},
	{0,1,1,1,0,0,0,0,0,0},
	{0,0,1,1,0,1,1,0,0,0},
	{0,1,0,0,1,0,0,1,0,0},
	{0,0,1,0,1,1,1,0,1,0},
	{0,0,0,1,0,0,1,0,0,1},
	{0,0,0,0,1,1,0,1,1,0},
	{0,0,0,0,0,0,0,1,1,1},
	{0,0,0,0,0,1,1,0,1,1}
	};
bool flag=true;
void find()
{
	//c[]保存每种方法的使用次数,最多3次,因为第4次就会回到原来位置
	//c[0]~c[9]是一种移动方案的组合,
     for(c[1]=0;c[1]<=3;c[1]++)
       for(c[2]=0;c[2]<=3;c[2]++)
         for(c[3]=0;c[3]<=3;c[3]++)
           for(c[4]=0;c[4]<=3;c[4]++)
             for(c[5]=0;c[5]<=3;c[5]++)
               for(c[6]=0;c[6]<=3;c[6]++)
                 for(c[7]=0;c[7]<=3;c[7]++)
                   for(c[8]=0;c[8]<=3;c[8]++)
                     for(c[9]=0;c[9]<=3;c[9]++)
                     {
						 //对每种移动方案进行检验
						 flag=true;        
						 for(int i=1;i<=9;i++)                     
							 a[i]=d[i];     
						 for(int i=1;i<=9;i++) //i:1~9,依次检验a[]的9个位置       
						 { 
							 for(int j=1;j<=9;j++) //对a[i]位置使用当前移动方案
								 a[i]+=b[j][i]*c[j];            
							 a[i]%=4;                    
							 if(a[i]!=0) //如果当前移动方案对a[i]位置不合适,不必继续检验a[i+1],退出检验该方案的循环以节省时间    
							 {                     
								 flag=false;                     
								 break;                   
							 }               
						 }                 
						 if(flag)//方案通过检验                  
							 if(c[1]+c[2]+c[3]+c[4]+c[5]+c[6]+c[7]+c[8]+c[9]<m)              
							 {		
								 m=c[1]+c[2]+c[3]+c[4]+c[5]+c[6]+c[7]+c[8]+c[9]; 
								 for(int i=1;i<=9;i++)	//记录该方案每种移动方法的使用次数		 
									 e[i]=c[i];                
							 }
                     }
}
int main()
{
    for(int i=1;i<=9;i++)
    {
            //cin>>a[i];
			fin>>a[i];
            a[i]/=3;
            a[i]%=4;
            d[i]=a[i]; 
    }
    find();
    flag=false;
    for(int i=1;i<=9;i++)
      for(int j=1;j<=e[i];j++)
      {
              if(flag)
              //cout<<" ";
			  fout<<" ";
              else
                flag=true;
              //cout<<i;
			  fout<<i;
      }
    //cout<<endl;
	fout<<endl;
    return 0;
}

转载于:https://my.oschina.net/u/347565/blog/62034

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值