代码随想录算法训练营第三十天|总结、332.重新安排行程、51.N皇后、37.解数独

本文主要是介绍代码随想录算法训练营第三十天|总结、332.重新安排行程、51.N皇后、37.解数独,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码随想录 (programmercarl.com)

总结

332.重新安排行程

欧拉通路和欧拉回路:

欧拉通路:对于图G来说,如果存在一条通路包含G的所有边,则该通路称为欧拉通路,也称欧拉路径。
欧拉回路:如果欧拉路径是一条回路,那么称其为欧拉回路。
欧拉图:含有欧拉回路的图是欧拉图。

题目中说必然存在一条有效路径,所以至少是半欧拉图,也可以是欧拉图。

深度优先搜索(DFS):

对每一个可能的分支路径深入到不能再深入为止,而且每个节点只能访问一次。

遍历欧拉图——Hierholzier算法

主要步骤:从一个可能的起点出发,进行深度优先搜索,但是每次沿着辅助边从每个顶点移动到另外一个顶点的时候,都需要删除这个辅助边。如果没有可移动的路径,则将所在节点加入到栈中(先进后出==所以后面步骤4需要逆序输入),并返回。

算法思路:

1)任选一点为起始点,并记录;

2)从起点出发到达任意一个邻接点,新到达的点成为新的起点,删除经过的边,删除孤立点,记录经过的点;

3)重复步骤2直至回到初始点,此时到达步骤1,将本次记录的点和上次记录的点集合拼接。若本图成为空图,到达步骤4;

4)逆序输出所有记录点。

只有入度与出度差为 1 的节点会导致死胡同

====代码待更新====

51.N皇后

皇后们的约束条件:

  1. 不能同行
  2. 不能同列
  3. 不能同斜线

棋盘的宽度就是for循环的长度,递归的深度就是棋盘的高度,这样就可以套进回溯法的模板里了

回溯算法主体里面需要放一个判断是否可以防止皇后Q的判断函数

其中对于不能同斜线,需要判断45°和135°,分别如下两种情况:

i - 2, j - 2
i - 1, j - 1
i, j
i - 2, j + 2
i - 1, j + 1
i, j


Java中ArrayList与LinkedList的区别 - 知乎 (zhihu.com)icon-default.png?t=N7T8https://zhuanlan.zhihu.com/p/33141246补充一点ArrayList和LinkedList的区别:

1、ArrayList的实现是基于数组,LinkedList的实现是基于双向链表。

2、对于随机访问,ArrayList优于LinkedList

3、对于插入和删除操作,LinkedList优于ArrayList

4、LinkedList比ArrayList更占内存,因为LinkedList的节点除了存储数据,还存储了两个引用,一个指向前一个元素,一个指向后一个元素。

class Solution {List<List<String>> res = new ArrayList<>();//需要在一开始就声明,因为后面res.add(Array2List(chessboard));会用到public List<List<String>> solveNQueens(int n) {//初始化所有棋盘格为.char[][] chessboard = new char[n][n];//注意此处的棋盘里面放的都是字符,所以需要定义为char类型的数组for (char[] c : chessboard) {Arrays.fill(c, '.');}backtracking(n, 0, chessboard);return res;}public void backtracking(int n, int row, char[][] chessboard){//n表示该棋盘格的规格大小,row表示当前遍历到的行数if (row == n){//表示递归终止条件,开始收集结果res.add(Array2List(chessboard));return;}for (int col = 0; col < n; col++) {if (isValid(n, row, col, chessboard)){chessboard[row][col] = 'Q';backtracking(n, row + 1, chessboard);chessboard[row][col] = '.';//回溯回去}}}public List Array2List(char[][] chessboard){//表示将数组类型的结果转为所需要的list的集合形式List<String> list = new ArrayList<>();for (char[] c : chessboard) {list.add(String.copyValueOf(c));}return list;}public boolean isValid(int n, int row, int col, char[][] chessboard){//以下操作相当于剪枝,即如果有违反题目要求的情况出现,直接就不进行回溯,减少进入递归的次数//检查列,以为此时调用该方法是固定列,这时遍历行去检查列,改变col去检查行for (int i = 0; i < row; i++) {if (chessboard[i][col] == 'Q'){return false;}}//检查45°斜线for (int i = row - 1, j = col - 1; i >= 0 && j >= 0; i--, j--) {if (chessboard[i][j] == 'Q'){return false;}}//检查135°斜线for (int i = row - 1, j = col + 1; i >= 0 && j < n; i--, j++) {if (chessboard[i][j] == 'Q'){return false;}}return true;}
}

37.解数独

class Solution {public void solveSudoku(char[][] board) {//没有new新的数组,直接修改原来传入的数组,所以返回值为voidbacktracking(board);}public boolean backtracking(char[][] board){//不需要终止条件,因为一旦该数独没有解,会直接返回false,不会陷入死循环//一个for循环遍历棋盘的行,一个for循环遍历棋盘的列,//一行一列确定下来之后,递归遍历这个位置放9个数字的可能性!for (int i = 0; i < 9; i++) {for (int j = 0; j < 9; j++) {if (board[i][j] != '.'){continue;//题目中初始的数独中,空白部分是.,此操作是为了跳过数独中的原始数字}for (char k = '1'; k <= '9'; k++) {if (isValid(i, j, k, board)){board[i][j] = k;if (backtracking((board))){// 如果找到合适一组立刻返回return true;}board[i][j] = '.';}}return false;// 因为如果一行一列确定下来了,这里尝试了9个数都不行,说明这个棋盘找不到解决数独问题的解!// 那么会直接返回,这也就是为什么没有终止条件也不会永远填不满棋盘而无限递归下去!}}// 遍历完没有返回false,说明找到了合适棋盘位置了return true;}public boolean isValid(int row, int col, char val, char[][] board){//检查同一行是否有重复for (int j = 0; j < 9; j++) {if (board[row][j] == val){return false;}}//检查同一列是否有重复for (int i = 0; i < 9; i++) {if (board[i][col] == val){return false;}}//检查同一个九宫格是否有重复int startRow = (row / 3) * 3;int startCol = (col / 3) * 3;for (int i = startRow; i < startRow + 3; i++) {for (int j = startCol; j < startCol + 3; j++) {if (board[i][j] == val){return false;}}}return true;}
}

这篇关于代码随想录算法训练营第三十天|总结、332.重新安排行程、51.N皇后、37.解数独的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/585265

相关文章

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型