N-Queens II:只记录下结果即可的N皇后问题

Follow up for N-Queens problem.

Now, instead outputting board configurations, return the total number of distinct solutions.

思路:还是回溯,只不过把打印结果换成计数即可。

class Solution {
    int sum = 0;
    public boolean test(int[] loc,int x,int y){  
        for(int i = 0;i<loc.length;i++){  
            if(Math.abs(i-x)==Math.abs(y-loc[i])||y==loc[i]){  
                return false;  
            }  
        }  
        return true;  
    }     
    public void save(){  
       sum++;
    }     
    public void dfs(int c,int n,int[] loc){  
        if(c>=n){  
            save();  
        }else{  
            for(int i = 0;i<n;i++){  
                if(test(loc,c,i)){  
                    loc[c] = i;  
                    dfs(c+1,n,loc);  
                    loc[c] = -111;  
                }  
            }     
        }  
    }   
    public int totalNQueens(int n) {  
        int[] loc = new int[n];  
        for(int i = 0;i<n;i++){  
            loc[i] = -111;  
        }  
        dfs(0,n,loc);  
        return sum;         
    }   
}


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值