模板

void dfs()//参数用来表示状态
{
if(到达终点状态)
{
...//根据题意添加
return;
}
if(越界或者是不合法状态)
return;
if(特殊状态)//剪枝
return ;
for(扩展方式)
{
if(扩展方式所达到状态合法)
{
修改操作;//根据题意来添加
标记;
dfs();
(还原标记);
//是否还原标记根据题意
//如果加上(还原标记)就是 回溯法
}
}
}

46. 全排列

class Solution {
public:
vector<vector<int>> res;
vector<int> vis;
vector<vector<int>> permute(vector<int>& nums) {
vector<int> path;
vis.resize(nums.size(), 0);
dfs(nums, path, 0);
return res;
}
void dfs(vector<int> & nums, vector<int>& path, int len){//参数表示状态
if(len == nums.size()){//递归出口
res.push_back(path);return;
}
for(int i = 0;i < nums.size(); i++){//扩展方式
if(vis[i] == 0){//扩展方式合法
path.push_back(nums[i]);
vis[i] = 1;
dfs(nums,path,len + 1);
vis[i] = 0;
path.pop_back();
}
}
}
};

47. 全排列 II 排序去重

class Solution {
public:
vector<vector<int>> res;
vector<int> vis;
vector<vector<int>> permuteUnique(vector<int>& nums) {
sort(nums.begin(),nums.end());
vis.resize(nums.size(),0);
vector<int> path;
dfs(nums,path, 0);
return res;
}
void dfs(vector<int>& nums, vector<int>& path, int depth){
if(depth == nums.size()){//递归出口
res.push_back(path);
return;
}
for(int i = 0; i < nums.size(); i++){
//在同一深度只会遍历第一个相同的数字,不同深度时vis[i-1] = 1
if(i && nums[i] == nums[i-1] && vis[i-1] == 0) continue;
if(vis[i] == 0){
vis[i] = 1;
path.push_back(nums[i]);
dfs(nums,path,depth + 1);
vis[i] = 0;
path.pop_back();
}
}
}
};

491. 递增子序列

class Solution {
public:
vector<vector<int>> res;
vector<int> vis;
vector<vector<int>> findSubsequences(vector<int>& nums) {
vis.resize(nums.size(),0);
vector<int> path;
dfs(nums,path,0);
return res;
}
void dfs(vector<int> & nums, vector<int>& path, int start){//参数表示状态,从前往后,depth改为start
if(path.size() >= 2){//过程状态也要记录
res.push_back(path);
}
if(start == nums.size()) return;
unordered_set<int> mp;//去重
for(int i = start;i < nums.size(); i++){//扩展方式
//if(vis[i] == 0){这里不需要vis
if((path.size() == 0 || nums[i] >= path.back()) && mp.count(nums[i]) == 0){
mp.insert(nums[i]);
path.push_back(nums[i]);
dfs(nums,path,i + 1);//这里别写错了
path.pop_back();
}
}
}
};

39. 组合总和

元素可以重复利用且没有顺序,所以不要vis数组

class Solution {
public:
vector<vector<int>> res;
vector<vector<int>> combinationSum(vector<int>& nums, int target) {
vector<int> path;
dfs(nums,path,0,target);
return res;
}
void dfs(vector<int> &nums,vector<int>& path, int start, int target){
//出口
if(target < 0) return;
if(target == 0){
res.push_back(path);
return;
}
//遍历
for(int i = start; i <nums.size(); i++){
path.push_back(nums[i]);
dfs(nums,path,i, target - nums[i]);
path.pop_back();
}
}
};

40. 组合总和 II 比上题多了一个去重操作;

class Solution {
public:
vector<vector<int>> res;
vector<vector<int>> combinationSum2(vector<int>& nums, int target) {
sort(nums.begin(),nums.end());//加个去重操作
vector<int> path;
dfs(nums,path,0,target);
return res;
}
void dfs(vector<int> &nums,vector<int>& path, int start, int target){
//出口
if(target < 0) return;
if(target == 0){
res.push_back(path);
return;
}
//遍历
for(int i = start; i <nums.size(); i++){
if(i > start && nums[i] == nums[i-1] ) continue;//注意是i > start
path.push_back(nums[i]);
dfs(nums,path,i+1, target - nums[i]); // start = i + 1
path.pop_back();
}
}
};

78. 子集

class Solution {
public:
vector<vector<int>> res;
vector<int> vis;
vector<vector<int>> subsets(vector<int>& nums) {
vis.resize(nums.size(),0);
vector<int> path;
dfs(nums,path,0);
return res;
}
void dfs(vector<int> & nums, vector<int>& path, int start){//参数表示状态,从前往后,depth改为start
res.push_back(path);
if(start == nums.size()) return;
for(int i = start;i < nums.size(); i++){//扩展方式
//似乎没条件
path.push_back(nums[i]);
dfs(nums,path,i + 1);//这里别写错了
path.pop_back();
}
}
};

90. 子集 II 上题基础上加个去重

class Solution {
public:
vector<vector<int>> res;
vector<int> vis;
vector<vector<int>> subsetsWithDup(vector<int>& nums) {
sort(nums.begin(), nums.end());//排序便于去重
vis.resize(nums.size(),0);
vector<int> path;
dfs(nums,path,0);
return res;
}
void dfs(vector<int> & nums, vector<int>& path, int start){//参数表示状态,从前往后,depth改为start
res.push_back(path);
if(start == nums.size()) return;
for(int i = start;i < nums.size(); i++){//扩展方式
if(i > start && nums[i] == nums[i-1]) continue; //去重
path.push_back(nums[i]);
dfs(nums,path,i + 1);//这里别写错了
path.pop_back();
}
}
};

进阶:N皇后问题

51. N皇后

class Solution {
public:
vector<vector<string>> res;
vector<vector<string>> solveNQueens(int n) {
string t = "";
for(int i = 0; i < n; i++) t += '.';
vector<string> path(n,t);
vector<vector<int>> vis(n, vector<int>(n,0));
dfs(path,vis,n,0);
return res;
}
void dfs(vector<string>& path,vector<vector<int>> &vis, int& n, int row){
if(row == n){//递归出口,前n行全部被赋值
res.push_back(path);return;
}
for(int j = 0; j < n; j++){//遍历一行
if(vis[row][j] == 0){//条件
path[row][j] = 'Q';
//注意,不能直接让vis变1和变0,否则后来的修改可能会改变原来的修改
for(int i = row; i < n; i++)vis[i][j]++;//该列
for(int i = row; i < n; i++){//对角线
if(j + i - row < n) vis[i][j + i - row]++;
if(j + row - i >= 0) vis[i][j + row - i]++;
}
dfs(path, vis, n, row + 1);
path[row][j] = '.';
for(int i = row; i < n; i++)vis[i][j]--;//该列
for(int i = row; i < n; i++){//对角线
if(j + i - row < n) vis[i][j + i - row]--;
if(j + row - i >= 0) vis[i][j + row - i]--;
}
}
}
}
};

37. 解数独

class Solution {
public:
int col[9][9] = {0};
int row[9][9] = {0};
int box[9][9] = {0};
void solveSudoku(vector<vector<char>>& board) {
int n = board.size();
//初始化
for(int i = 0; i <9; i++)
for(int j = 0; j < 9; j++){
if(board[i][j] != '.'){
int t = board[i][j] - '1';
col[j][t]++;
row[i][t]++;
box[i/3*3+ j/3][t]++;
}
}
dfs(board, 0, 0);
}
//传参 int a[][9] 或者 int (*a)[9] 而不是 (int*)[9] a
// box x/3*3 + y/3 而不是 x/3 + y/3;
// (y + 1)%3 而不是 (++y)/3
bool dfs(vector<vector<char>>& board, int x, int y){
if(x == 9) return true;//递归出口
//特殊状态
if(board[x][y] != '.') return dfs(board,x + (y==8),(++y)%9);
for(int k = 0; k < 9; k++){//遍历
//条件
if(row[x][k] || col[y][k] || box[x/3*3 + y/3][k]) continue;
board[x][y] = k + '1';
row[x][k]++;col[y][k]++;box[x/3*3 + y/3][k]++;
if(dfs(board,x + (y==8),(y + 1)%9)) return true;//找到一个解就退出
board[x][y] = '.';
row[x][k]--;col[y][k]--;box[x/3*3 + y/3][k]--;
}
return false;
}
};

dfs-入门模板的更多相关文章

  1. 算法学习之BFS、DFS入门

    算法学习之BFS.DFS入门 0x1 问题描述 迷宫的最短路径 给定一个大小为N*M的迷宫.迷宫由通道和墙壁组成,每一步可以向相邻的上下左右四格的通道移动.请求出从起点到终点所需的最小步数.如果不能到 ...

  2. HDU 1251 统计难题(字典树入门模板题 很重要)

    统计难题 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131070/65535 K (Java/Others)Total Submi ...

  3. 母函数(Generation Function) 入门 + 模板

    转自:母函数 入门 + 模板  感谢 在数学中,某个序列的母函数(Generating function,又称生成函数)是一种形式幂级数,其每一项的系数可以提供关于这个序列的信息.使用母函数解决问题的 ...

  4. DFS 算法模板

    dfs算法模板: 1.下一层是多节点的dfs遍历 def dfs(array or root, cur_layer, path, result): if cur_layer == len(array) ...

  5. DFS算法(——模板习题与总结)

    首先,需要说明的是搜索算法本质上也是枚举的一种,时间复杂度还是很高的,遇到问题(特别是有水平的比赛上),不要优先使用搜索算法. 这里总结一下DFS算法: 1.从图中某个顶点出发,访问v. 2.找出刚访 ...

  6. Oil Deposits(poj 1526 DFS入门题)

    http://poj.org/problem?id=1562                                                                       ...

  7. 网络流之最大流与最小费用流入门&&模板

    理解处 刷题处 模板处 最大流模板 处理重边的+(优化) #include<bits/stdc++.h> using namespace std; ; const int INF = 0x ...

  8. hdu 3549 Flow Problem【最大流增广路入门模板题】

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=3549 Flow Problem Time Limit: 5000/5000 MS (Java/Others ...

  9. 图的dfs遍历模板(邻接表和邻接矩阵存储)

    我们做算法题的目的是解决问题,完成任务,而不是创造算法,解题的过程是利用算法的过程而不是创造算法的过程,我们不能不能陷入这样的认识误区.而想要快速高效的利用算法解决算法题,积累算法模板就很重要,利用模 ...

  10. hdu:2089 ( 数位dp入门+模板)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2089 数位dp的模板题,统计一个区间内不含62的数字个数和不含4的数字个数,直接拿数位dp的板子敲就行 ...

随机推荐

  1. python进阶之路2——解释器软件安装

    内容概要 计算机五大组成部分 计算机三大核心硬件 操作系统 编程与编程语言 编程语言发展史 编程语言的分类 python解释器下载与安装 python解释器多版本共存 pycharm安装 计算机五大组 ...

  2. BC4-牛牛学说话之-浮点数

    题目描述 会说整数之后,牛牛开始尝试浮点数(小数),输入一个浮点数,输出这个浮点数. 输入描述 输入一个浮点数 输出描述 输出一个浮点数,保留三位小数 示例 1 输入:1.359578 输出:1.36 ...

  3. 通过this引用成员方法-类的构造器

    通过this引用成员方法 this代表当前对象,如果需要引用的方法就是当前类中的成员方法,那么可以使用"this成员方法"的格式来使用方法引用.首先是简单的函数式接口︰ 下面是一个 ...

  4. 逗号(,)运算符在Javascript中

    逗号运算符 逗号运算符是二元运算符,它能够先执行运算符左侧的操作数,然后再执行右侧的操作数,最后返回右侧操作数的值. 逗号表达式: 一般形式:表达式1,表达式2,表达式3,......表达式n 求解过 ...

  5. 11月22日内容总结——存取数据的历史和数据库的介绍、MySQL介绍、下载和相关操作

    目录 一.存取数据的演变史 1.文本文件 2.软件开发目录规范 3.数据库服务(重点) 1.数据库管理软件的由来 ①程序所有的组件就不可能运行在一台机器上 ②数据安全问题 ③并发 总结 二.数据库软件 ...

  6. Pytest插件之pytest-base-url切换测试环境

    Pytest插件之pytest-base-url切换测试环境 安装  pip install pytest-base-url 应用场景 利用参数--base-url或者配置(pytest.ini中ba ...

  7. 元数据库 information_schema.tables

    转  https://www.cnblogs.com/ssslinppp/p/6178636.html 1.information_schema数据库 对于mysql和Infobright等数据库,i ...

  8. 强大的word插件,让工作更高效:不坑盒子 2023版

    不坑盒子简介 很多朋友在工作过程中需要对Word文档进行编辑处理,如果想让Word排版更有效率可以试试小编带来的这款不坑盒子软件,这是一个非常好用的插件工具,专门应用在Word文档中,支持Office ...

  9. KMP 算法(Knuth–Morris–Pratt algorithm)的基本思想

    KMP 算法(Knuth–Morris–Pratt algorithm)的基本思想 阅读本文之前,您最好能够了解 KMP 算法解决的是什么问题,最好能用暴力方式(Brute Force)解决一下该问题 ...

  10. dom添加样式可以这样写

    1.原生 js添加样式很多时可以合并在一起写: var oPopwin = document.getElementById('vpage'); oPopwin.style.margin = 'init ...