POJ 1166 The Clocks G++

9个时钟标号A到I。0表示12点,1表示3点,2表示6点,3表示9点。9个按钮,按动按钮如图相应时钟顺时针转动90度。给出初始时钟,求怎么操作最后所有时钟在12点。

#include <iostream>
using namespace std;
//抄博友好程序  
int a[11];//初始状态 
int b[11];//每种变化的次数 
int c[11];//终止状态 
int main()
{
	for(int i=1;i<=9;i++)
	{
		cin>>a[i];
	}
	for(b[1]=0;b[1]<=3;b[1]++)//抄博友程序 
	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;//A
		c[2]=(a[2]+b[1]+b[2]+b[3]+b[5])%4;//B
		c[3]=(a[3]+b[2]+b[3]+b[6])%4;//C
		c[4]=(a[4]+b[1]+b[4]+b[5]+b[7])%4;//D
		c[5]=(a[5]+b[1]+b[3]+b[5]+b[7]+b[9])%4;//E
		c[6]=(a[6]+b[3]+b[5]+b[6]+b[9])%4;//F
		c[7]=(a[7]+b[4]+b[7]+b[8])%4;//G
		c[8]=(a[8]+b[5]+b[7]+b[8]+b[9])%4;//H
		c[9]=(a[9]+b[6]+b[8]+b[9])%4;//I	
		if(c[1]+c[2]+c[3]+c[4]+c[5]+c[6]+c[7]+c[8]+c[9]==0)
		{
			for(int i=0;i<b[1];i++)cout<<"1 ";
			for(int i=0;i<b[2];i++)cout<<"2 ";
			for(int i=0;i<b[3];i++)cout<<"3 ";
			for(int i=0;i<b[4];i++)cout<<"4 ";
			for(int i=0;i<b[5];i++)cout<<"5 ";
			for(int i=0;i<b[6];i++)cout<<"6 ";
			for(int i=0;i<b[7];i++)cout<<"7 ";
			for(int i=0;i<b[8];i++)cout<<"8 ";
			for(int i=0;i<b[9];i++)cout<<"9 ";	
			cout<<endl;		
		}
	}	
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值