[蓝桥杯2016初赛]寒假作业

蓝桥杯题目:寒假作业

现在小学的数学题目也不是那么好玩的。
看看这个寒假作业:

在这里插入图片描述
每个方块代表1~13中的某一个数字,但不能重复。
比如:
6 + 7 = 13
9 - 8 = 1
3 * 4 = 12
10 / 2 = 5
以及:
7 + 6 = 13
9 - 8 = 1
3 * 4 = 12
10 / 2 = 5
就算两种解法。(加法,乘法交换律后算不同的方案)
你一共找到了多少种方案?

输出
请填写表示方案数目的整数。

这是一道简单的dfs的题目,唯一容易出错的地方就是在判断第四个除法算式时要注意先去判断能否整除。

代码:

//寒假作业
#include<iostream>
using namespace std;
int sum=0;
int book[14];
int g[4][3];

bool judge(int x,int y,int n){//判断在(x,y)处放n是否可行 
	if(y!=2)return true;	//每当填写完一行时进行判断
	
	if(x==0&&(g[0][0]+g[0][1]==n)) return true;
	else if(x==1&&(g[1][0]-g[1][1]==n)) return true;
	else if(x==2&&(g[2][0]*g[2][1]==n)) return true;
	//判断除法的时候首先要保证能够整除 
	else if(x==3&&(g[3][0]%g[3][1]==0)&&(g[3][0]/g[3][1]==n)) return true;
	return false;
}
void dfs(int x,int y){//用深搜求解 
	if(x==4&&y==0){//到达递归的终点 
		sum++;
		return;
	}
	int i;
	for(i=1;i<=13;i++)
		if(book[i]==0&&judge(x,y,i)){
			book[i]=1;
			g[x][y]=i;
			if(y<2)dfs(x,y+1);
			else dfs(x+1,0);
			book[i]=0;
		} 
}
int main()
{
	int i,j;
	for(i=0;i<14;i++) book[i]=0;	//赋初始值 
				
	dfs(0,0);
	cout<<sum<<endl;
	return 0;	
 } 

答案:64

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值