dfs暴力满足等式

满足等式XXX+XXX=XXX的等式有多少个,X的范围为1到9,

import java.util.*;

public class Main {
    static Scanner in = new Scanner(System.in);
    static int[] bool= new int[10];
    static int[] a= new int[10];
    static int sum=0;
    static void dfs(int step){
        //前面9个盒子已经填满,判断结果的正确性
        if(step==9){
            if((a[0]*100+a[1]*10+a[2])+(a[3]*100+a[4]*10+a[5])
                    ==(a[6]*100+a[7]*10+a[8])){
                sum++;
            System.out.println((a[0]*100+a[1]*10+a[2])+"+"+(a[3]*100+a[4]*10+a[5])
                    +"=="+(a[6]*100+a[7]*10+a[8]));    
            }
            else
                return;
                
        }
        //每当站在一个盒子面前枚举所有可能,可能是1到9任一个数字
        for (int i = 1; i <= 9; i++) {
            //每个数字仅且可以使用一次
            if(bool[i]==0){
                a[step]=i;
                bool[i]=1;
                
                dfs(step+1);
                bool[i]=0;
            }
        }
        return;
    }
    public static void main(String[] args) {
       Arrays.fill(bool, 0);
            dfs(0);        
         System.out.println(sum/2);
   }
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值