[Leetcode]N-Queens II
来源:互联网 发布:淘宝卖家常用app 编辑:程序博客网 时间:2024/06/17 07:03
Follow up for N-Queens problem.
Now, instead outputting board configurations, return the total number of distinct solutions.
class Solution {public: /*algorithm: DFS */ vector<int>getNextCandiates(vector<int>&solution,int n) { vector<int>result; for(int i = 0; i < n;i++){ bool selected = true; for(int k = 0;k < solution.size();k++){ if(i == solution[k] || //same column or same k=1/-1 (k=(y2-y1)/(x2-x1)) abs(i-solution[k])==abs((int)solution.size()-k)){ selected = false; break; } } if(selected)result.push_back(i); } return result; } void dfs(int n,int start,int &sum,vector<int>&solution){ if(start == n){ //find one solution,reach last line sum++; return; } vector<int>candiates = getNextCandiates(solution,n); for(int k = 0;k < candiates.size();k++){ solution.push_back(candiates[k]); dfs(n,start+1,sum,solution); solution.pop_back(); } } int totalNQueens(int n) { vector<int>solution; int sum = 0; dfs(n,0,sum,solution); return sum; }};
0 0
- LeetCode: N-Queens II
- LeetCode : N-Queens II
- [Leetcode] N-Queens II
- 【leetcode】N-Queens II
- LeetCode: N Queens II
- [LeetCode]N-Queens II
- LeetCode - N-Queens II
- LeetCode:N-Queens II
- 【leetcode】N-Queens II
- LeetCode:N-Queens II
- Leetcode: N-Queens II
- leetcode N-Queens II
- LeetCode | N-Queens II
- Leetcode: N-Queens II
- LeetCode N-Queens II
- Leetcode N-Queens II
- N-Queens II -- LeetCode
- N-Queens II - LeetCode
- 前台页面实现可选可编辑效果
- Android中Handler和AsyncTask
- LNAMP Linux+Apache+Nginx+MySQL+PHP
- HBA 卡 知识
- iOS 7 使用CGAffineTransformMakeRotation在autolayout布局下旋转图片变形.
- [Leetcode]N-Queens II
- Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式)介绍
- UI测试
- Kaggle 机器学习竞赛冠军及优胜者的源代码汇总
- java执行字符串公式
- Android简单实现下拉刷新和上拉刷新
- Android之检测文本内容是否为空时左右摆动效果
- Git命令提交项目代码
- Android Studio R文件丢失 为什么不能重建了!