超超终于向他的女神小美表白了。可是小美只喜欢聪明的程序员,当场给他出了道难题,题目如下:给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A、B、C是用火柴棍拼出的整数(若该数非零,则最高位不能是0)。用火柴棍拼数字0-9的拼法如图所示:
注意:
1. 加号与等号各自需要两根火柴棍
2. 如果A≠B,则A+B=C与B+A=C视为不同的等式(A、B、C>=0)
3. n根火柴棍必须全部用上
超超分分钟就解出来了。
亲爱的小伙伴们,你们是不是也可以分分钟搞定这道难题呢?
public static void main(String[] args){
int a,b,c,m,i,sum=0;
Scanner sc=new Scanner(System.in);
m=sc.nextInt();
for(a=0;a<=1111;a++){
for(b=0;b<=1111;b++){
c=a+b;
//fun方法用来计算一个数需要火柴棍的总数,因为等号要用两根火柴棍,
//加号也用两根火柴棍,所以a+b+c=m-4(20)
if(fun(a)+fun(b)+fun(c)==m-4){
System.out.println(a+"+"+b+"="+c);
sum++;
}
}
}
System.out.println(sum);//可以排列的总数
}
public static int fun(int x){
int num=0;//用来计数的变量
int[] f={6,2,5,5,4,5,6,3,7,6};//用一个数组来记录0~9每个数字需要的柴棍。
while(x/10!=0){//如果这样的话,说明这个数至少有两位
num=num+f[x%10];//获得x的末位数字病将此数所用到的火柴棍根数累加到sum中
x=x/10;//去掉x的末位数字,例如123的值现在为12;
}
//最后加上此时x所需要用的火柴棍的根数(此时x一定是一位数)
num=num+f[x];
return num;
}