玩转算法之面试 第八章-递归与回溯

树形问题
leetcode:17
在这里插入图片描述
在这里插入图片描述
1 字符串的合法性 (是否包括1,*和#号键)
2 空字符串
3 多个解的顺序
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
部分源代码如下:

在这里插入代码片
#include<cstring>using namespace std;private:const string letterMap[10]={" ",//0"",//1"abc",//2"def","ghi","jkl","mno","pqrs","tuv","wxyz"}void findCombination(const string &digits, int index, const string &s){if(index==digits.size()){//保存sreturn; }char c = digits[index];assert(c>='0' && c<='9' && c!='1');string letters=letterMap[c-'0'];//找到当前数字对应的阿斯玛值for(int i=0; i<letters.size();i++)findCombinations(digits,index+1,s+letters[i]);return; }class Solution{public:vector<string> letterCombinations(string digits){}
}; int main(){return 0;
}

8-23
递归调用的一个重要特征就是要返回–回溯,回溯法是暴力解法的一个主要实现手段

leetcode 93:
返回所有合法的ip地址
在这里插入图片描述
leetcode 131
返回所有拆分的可能,所有拆分的子串都是回文串
在这里插入图片描述
回溯算法的应用:排列问题
leetcode 46
返回所有元素排列的可能
在这里插入图片描述
在这里插入图片描述
递归形式如下:
在这里插入图片描述
部分源代码如下:
在这里插入图片描述
在这里插入图片描述

在这里插入代码片
vector<vector<string>solveNQueens(int n){}
private:vector<vector<int>> res;vector<bool> used;//来判断数组中第i个元素是否在p中	void generatePermutation(const vector<int &nums, int index, vector<int>& p){if(index==nums.size()){res.push_back(p);return;}for(int i=0;i<nums.size();i++)if(!used[i]){//将nums[i]添加在p中p.push_back(nums[i]);used[i]=true;generatePermutation(nums,index+1,p);p.pop_back();used[i]=false; //状态进行回溯 }}
public:vector<vector<int>> permute(vector<int>& nums){res.clear();if(nums.size()==0)return res;used=vector<bool>(nums.size(),false);vector<int> p;generatePermutation(nums,0,p);return res;	}

思考题:leetcode 47
在这里插入图片描述
8-45 组合问题
leetcode 77
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

部分代码如下:

在这里插入代码片
private:vector<vector<int>> res;void generateCombinations(int n, int k, int start, vector<int> &c){if(c.size()==k){res.push_back(c);return;}for(int i=start;i<=n;i++){c.push_back(i);genenrateCombinations(n,k,i+1,c)c.pop_back();}return;	vector<vector<int>> combine(int n, int k){res.clear();if(n<=0||k<=0||k>n)return res;vector<int>c;generateCombinations(n,k,1,c);return res;} 

优化思想:剪枝
在这里插入图片描述
leetcode 39
在这里插入图片描述
leetcode 40
在这里插入图片描述
leetcode 216
在这里插入图片描述
leetcode 78
在这里插入图片描述
leetcode 90

在这里插入图片描述
leetcode 401

在这里插入图片描述
8-67 二维平面上使用回溯法
leetcode79
在这里插入图片描述
在这里插入图片描述
方向:为顺时针方向,上右下左
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


在这里插入图片描述
部分代码如下:

在这里插入代码片
private:int d[4][2]={{-1,0},{0,1},{1,0},{0,-1}} ;int m,n; vector<vector<bool>> visited;bool inArea(int x, int y){return x>=0 && x<m && y>=0 && y<n;}//从board[startx][starty]开始,寻找word【index...word.size()] bool searchWord(const vector<vector<char>> &board, const string& word, int index,int startx,int starty){if(index==word.size()-1)return board[startx][starty]==qord[index];if(board[startx][starty]==word[index]){visited[startx][starty]=true;//从startx,starty出发,向四个方向寻找for(int i=0; i<4; i++){int newx=startx+d[i][0];int newy=starty+d[i][1];if(inArea(newx,newy) && !visited[newx][newy] && searchWord(board,word,index+1,newx,newy)return true;}visited[startx][starty]=false; }}bool exsit(vector<vector<char>>& board, string word){m=board.size();asser(m>0);n=board[0].size();visited=vector<vector<bool>>(m,vector<bool>(n,false));for(int i=0;i<board.size(); i++){for(int j=0; j<board[i].size(); j++)if(searchWord(board,word,0,i,j))return true;return false;}
}

floodfill算法,一类经典问题
leetcode 200 number of islands
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
从初始点开始,来一个深度优先遍历

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
部分代码如下:

在这里插入代码片using namespace std;
class Solution{private:int d[4][2]={{-1,0},{0,1},{1,0},{0,-1}};int m,n; //m,n分别存储陆地的长宽度 vector<vector<bool>> visited;//标记已经被访问过的陆地 bool inArea(int x, int y){return x>=0 && x<m && y>=0 && y<n;}void dfs(vector<vector<char>>& grid,int x,int y){visited[x][y]=true;for(int i=0; i<4; i++){int newx=x+d[i][0];int newy=y+d[i][1];if(inArea(newx,newy) && !visited[newx][newy] && grid[newx][newy]=='1')dfs(drid,newx,newy);}return;}public:int numIsLands(vector<vector<char>>& grid){m=grid.size();if(m==0){return 0;}n=grid[0].size();visited=vector<vector<bool>>(m,vector<bool>(n,false));int res=0;for(int i=0; i<m;i++)for(int j=0;j<n;j++)if(grid[i][j]=='1' && !visited[i][j]){res++;dfs(grid,i,j);}}
};int main(){return 0;
}

leetcode 130 包围字符
在这里插入图片描述
leetcode;417
在这里插入图片描述
在这里插入图片描述

回溯法是经典人工智能的基础
在这里插入图片描述
八皇后问题的解:
先来看看四皇后问题:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
快速判断不合法的情况
在这里插入图片描述
在这里插入图片描述
可以发现每个对角线各个空格元素相加为定值

在这里插入图片描述
第二个对角线:可以发现相减是一个定值

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
n皇后的优化问题:
leetcode 52;
求n皇后问题的所有解的个数

leetcode:37
求解数独问题
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/480080.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

动态规划理论学习

文章目录1. 理论总结1.1 “一个模型”1.2 “三个特征”1.2.1 最优子结构1.2.2 无后效性1.2.3 重复子问题2. 实例剖析2.1 问题描述2.2 两种DP解题思路2.2.1 状态转移表2.2.2 状态转移方程3. 四种算法思想比较1. 理论总结 动态规划理论总结为“一个模型、三个特征”。 1.1 “一…

Java多线程系列(四):4种常用Java线程锁的特点,性能比较、使用场景

多线程的缘由 在出现了进程之后&#xff0c;操作系统的性能得到了大大的提升。虽然进程的出现解决了操作系统的并发问题&#xff0c;但是人们仍然不满足&#xff0c;人们逐渐对实时性有了要求。 使用多线程的理由之一是和进程相比&#xff0c;它是一种非常花销小&#xff0c;切…

论文浅尝 | Global Relation Embedding for Relation Extraction

链接&#xff1a;https://arxiv.org/abs/1704.05958Introduction在关系抽取任务中&#xff0c;通常采用远程监督的方式自动生成数据集。由于实体对间可能存在多关系&#xff0c;生成的数据集往往存在大量噪音。本文对文本中的关系表述&#xff08;textual relation&#xff09;…

tensorflow--模型的保存和提取

参考&#xff1a; TensorFlow&#xff1a;保存和提取模型 最全Tensorflow模型保存和提取的方法——附实例 模型的保存会覆盖&#xff0c;后一次保存的模型会覆盖上一次保存的模型。最多保存近5次结果。应当保存效果最优时候的模型&#xff0c;而不是训练最后一次的模型。所以…

推荐模型是怎样由窄变宽、越变越深的?

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 邢智皓编 | 兔子酱当前&#xff0c;深度学习推荐模型已经成功应用于推荐、广告、搜索等领域&#xff0c;但在了解它之前&#xff0c;简单回顾传统推荐模型仍是有必要的&#xff0c;原因如下&#xff1a;…

动态规划应用--找零钱

文章目录1. 问题描述2. 问题分析2.1 回溯法求解2.2 DP状态转移方程法2.3 DP状态转移表法1. 问题描述 找零问题&#xff0c;在贪心算法讲过。但是贪心不一定能得出最优解。假设有几种不同币值的硬币v1&#xff0c;v2&#xff0c;.……vn&#xff08;单位是元&#xff09;。如果…

玩转算法之面试第九章-动态规划

动态规划&#xff1a; 9-12 斐波那契数列 对重复计算&#xff0c;进行优化&#xff0c;进行记忆化搜索 假设基本的问题已经被解决&#xff0c;依次内推。 动态规划&#xff1a;将原问题拆解成若干个子问题&#xff0c;同时保存子问题的答案&#xff0c;使得每个子问题只求…

领域应用 | 从本体论开始说起——运营商关系图谱的构建及应用

本文转载自公众号&#xff1a;中国联通大数据。联通大数据技术专家闫龙将从“本体论”说起&#xff0c;为大家介绍联通大数据关系图谱的构建与应用。一&#xff0e;本体论万维网之父Tim Berners-Lee教授在1998年将语义网络&#xff08;Semantic web&#xff09;带入人类的视线。…

史上最强多线程面试44题和答案:线程锁+线程池+线程同步等

最全BAT必考题答案系列 最全MySQL面试60题和答案 史上最全Spring面试71题与答案 史上最全Redis面试49题&#xff08;含答案&#xff09;:哨兵复制事务集群持久化等 分布式缓存RedisMemcached经典面试题和答案 最全Java锁详解&#xff1a;独享锁/共享锁公平锁/非公平锁乐观锁…

部门直推!百度大搜索招聘NLP、搜索方向算法工程师!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术工作职责负责百度搜索排序相关性&#xff08;Relevance&#xff09;策略。 职位要求-了解主流机器学习算法。 -优秀的分析问题和解决问题的能力&#xff0c;对解决具有挑战性问题充满激情。 -C/C语言编程&…

POJ 1276 ATM凑钱(动态规划)(未解答)

文章目录1. 题目1.1 题目链接1.2 题目大意1.3 解题思路2. 代码2.1 Accepted代码1. 题目 1.1 题目链接 http://poj.org/problem?id1276 1.2 题目大意 需要凑的钱最多100000&#xff0c;面额最多10种&#xff0c;每种张数最多1000&#xff0c;面额最大不超过1000 1.3 解题思…

论文浅尝 | 为基于知识库的问答构建形式查询生成

论文笔记整理&#xff1a;刘晓臻&#xff0c;东南大学计算机科学与工程学院本科生。Citation: H.Zafar, G. Napolitano, and J. Lehmann. Formal query generation for questionanswering overknowledge bases. ESWC, 2018.https://link.springer.com/content/pdf/10.1007%2F97…

Java多线程系列(十一):ReentrantReadWriteLock的实现原理与锁获取详解

我们继续Java多线程与并发系列之旅&#xff0c;之前我们分享了Synchronized 和 ReentrantLock 都是独占锁&#xff0c;即在同一时刻只有一个线程获取到锁。 然而在有些业务场景中&#xff0c;我们大多在读取数据&#xff0c;很少写入数据&#xff0c;这种情况下&#xff0c;如…

这篇顶会paper,讲述了疫情期间憋疯的你和我

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术编 | 小轶2020年净忙着见证历史了。年初疫情爆发后&#xff0c;大家的生活模式也因为疫情发生了巨变。经历了史上最长假期&#xff0c;躺尸太久&#xff0c;到后来满脑子只想开学/复工。今年KDD会议上有一篇很…

论文浅尝 | Knowledge Vault: 全网规模的知识概率融合方法

论文笔记整理&#xff1a;吴桐桐&#xff0c;东南大学博士生&#xff0c;研究方向为自然语言处理。链接&#xff1a;https://www.cs.ubc.ca/~murphyk/Papers/kv-kdd14.pdf基于机器学习&#xff0c;Knowledge Vault不仅能够从多个来源&#xff08;文本&#xff0c;表格数据&…

java程序员的必用的9款开发工具

今天推荐java程序员开发利器&#xff0c;包含如如下&#xff1a; 开发环境&#xff1a; Eclipse IntelliJ IDEA IntelliJ在业界被公认为最好的java开发工具之一&#xff0c;尤其在智能代码助手、代码自动提示、重构、J2EE支持、各类版本工具&#xff08;git、svn等&#xff…

动态规划应用--搜索引擎拼写纠错

文章目录1. 字符串相似度1.1 莱文斯坦距离1.2 最长公共子串长度2. 计算编辑距离2.1 莱文斯坦距离2.2 最长公共子串长度3. 搜索引擎拼写纠错4. 练习题在 Trie树那节讲过&#xff0c;利用Trie可以进行关键词提示&#xff0c;节省输入时间。在搜索框中你不小心打错了字&#xff0c…

玩转算法之面试第十章-贪心算法

leetcode 455 分配饼干 尝试将最大的饼干给最贪心的朋友 如果满足&#xff0c;则1 如果不满足&#xff0c;则将最大的饼干给次贪心的朋友&#xff0c;一次类推 试图让最多的小朋友开心 在这里插入代码片 #include<iostream> #include<vector>using namespace …

论文浅尝 | 基于知识库的自然语言理解 04#

本文转载自公众号&#xff1a;知识工场。罗康琦&#xff0c;上海交通大学计算机系2019届博士&#xff0c;研究方向为自然语义理解和知识图谱。2012年获得华中科技大学软件工程学士学位&#xff0c;现就职于京东数据科学实验室&#xff08;Data Science Lab&#xff09;。他曾在…

BERT跨模态之后:占领了视觉常识推理任务榜单TOP 2!

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 小鹿鹿lulu编 | YY前言由于 BERT-like 模型在 NLP 领域上的成功&#xff0c;研究者们开始尝试将其应用到更为复杂的 多模态 任务上。要求模型除文本数据以外&#xff0c;还要接收其他模态的数据&#xf…