【LeetCode Hot100】回溯篇

前言

        本文用于整理LeetCode Hot100中题目解答,因题目比较简单且更多是为了面试快速写出正确思路,只做简单题意解读和一句话题解方便记忆。但代码会全部给出,方便大家整理代码思路。


46. 全排列

一句话题意

        给定一个无重复数字的序列,求序列的全排列。

一句话题解

        dfs扔数求全排列。

class Solution {List<List<Integer>> ans;public List<List<Integer>> permute(int[] nums) {ans =new ArrayList<>();dfs(nums,new ArrayList<>(),new HashSet<>());return ans;}void dfs(int[] nums,List<Integer> arr,Set<Integer> u){if(arr.size() == nums.length){ans.add(new ArrayList<>(arr));return ;}for(int i=0;i<nums.length;i++){if(u.contains(nums[i]))continue;arr.add(nums[i]);u.add(nums[i]);dfs(nums,arr,u);arr.remove(arr.size()-1);u.remove(nums[i]);}}
}

78. 子集

一句话题意

        给定一个数组,求数组中所有的子集。

一句话题解

        二进制枚举。

class Solution {public List<List<Integer>> subsets(int[] nums) {int n = nums.length;List<List<Integer>> ans = new ArrayList<>();for(int i=(1<<n)-1;i>=0;i--){List<Integer> arr = new ArrayList<>();int ii=i;for(int j=0;j<n;j++){if(ii%2==1)arr.add(nums[j]);ii/=2;}ans.add(arr);}return ans;}
}

17. 电话号码的字母组合

一句话题意

        给定一个旧电话上数字和字符的映射,问给定一串数字序列,可能的字母组合有哪些。

一句话题解

        先将数字做映射,然后dfs组合即可。

class Solution {Map<Character, String> mp = new HashMap<>() {{put('2', "abc");put('3', "def");put('4', "ghi");put('5', "jkl");put('6', "mno");put('7', "pqrs");put('8', "tuv");put('9', "wxyz");}};public List<String> letterCombinations(String digits) {List<String> ans = new ArrayList<String>();if (digits.length() == 0) {return ans;}dfs(ans, digits, 0, new StringBuilder());return ans;}void dfs(List<String> ans,String digits,int i,StringBuilder s){if(i==digits.length()){ans.add(s.toString());return ;}String now=mp.get(digits.charAt(i));for(int j=0;j<now.length();j++){s.append(now.charAt(j));dfs(ans,digits,i+1,s);s.deleteCharAt(i);}}
}

39. 组合总和

一句话题意

        给定一个数字序列和一个目标值,数字序列中每个可以取任意个,问组成目标值的所有组合。

一句话题解

        DFS,如果没有达到目标值,则尽量往里面扔值。

class Solution {public List<List<Integer>> combinationSum(int[] candidates, int target) {List<List<Integer>> ans = new ArrayList<>();List<Integer> c = new ArrayList<>();dfs(candidates, target, ans, c, 0);return ans;}public void dfs(int[] candidates, int target, List<List<Integer>> ans, List<Integer> c, int i) {if (i == candidates.length) {return;}if (target == 0) {ans.add(new ArrayList<Integer>(c));return;}dfs(candidates, target, ans, c, i + 1);if (target - candidates[i] >= 0) {c.add(candidates[i]);dfs(candidates, target - candidates[i], ans, c, i);c.remove(c.size() - 1);}}
}

22. 括号生成

一句话题意

        构建所有满足含有n对括号的括号序列。

一句话题解

        dfs,优先放左括号,然后再放右括号。

class Solution {public List<String> generateParenthesis(int n) {List<String> ans = new ArrayList<String>();dfs(ans, new StringBuilder(), 0, 0, n);return ans;}public void dfs(List<String> ans, StringBuilder s, int l, int r, int n) {if (s.length() == n * 2) {ans.add(s.toString());return;}if (l < n) {s.append('(');dfs(ans, s, l + 1, r, n);s.deleteCharAt(s.length() - 1);}if (r < l) {s.append(')');dfs(ans, s, l, r + 1, n);s.deleteCharAt(s.length() - 1);}}
}

79. 单词搜索

一句话题意

        给定一个二维字符数组,规定每个字符只能使用一次,问给定的单词是否出现在二维数组中过。

一句话题解

        DFS,额外设定一个访问数组即可。

class Solution {int n;int m;char[][] dt;boolean[][] v;String s;boolean flag=false;public boolean exist(char[][] board, String word) {this.n=board.length;this.m=board[0].length;this.dt=board;this.v=new boolean[n][m];this.s=word;for(int i=0;i<n;i++)for(int j=0;j<m;j++)v[i][j]=false;for(int i=0;i<n;i++){for(int j=0;j<m;j++){if(board[i][j]==word.charAt(0)){v[i][j]=true;dfs(i,j,1);v[i][j]=false;if(flag)return true;}}}return false;}int[][] fx={{0,1},{1,0},{-1,0},{0,-1}};void dfs(int i,int j,int idx){if(idx == s.length()){flag=true;return;}for(int k=0;k<4;k++){int ii=i+fx[k][0];int jj=j+fx[k][1];if(ii<0||ii>=n||jj<0||jj>=m||v[ii][jj]||dt[ii][jj]!=s.charAt(idx))continue;v[ii][jj]=true;dfs(ii,jj,idx+1);v[ii][jj]=false;}}
}

131. 分割回文串

一句话题意

        给定一个字符串,可以任意分割字符串,求当进行分割后所有子串都是回文串的分割方式有哪些。

一句话题解

        先DP求出所有回文子串,然后dfs进行分割。

class Solution {int n;boolean[][] dp;String s;List<String> arr;List<List<String>>ans;public List<List<String>> partition(String s) {this.s=s;this.n=s.length();this.dp=new boolean[n][n];this.ans=new ArrayList<>();this.arr=new ArrayList<>();for(int i=0;i<n;i++)for(int j=0;j<n;j++)dp[i][j]=true;for(int i=n-1;i>=0;i--){for(int j=i+1;j<n;j++){dp[i][j]= s.charAt(i) == s.charAt(j) && dp[i+1][j-1];}}dfs(0);return ans;}void dfs(int i){if(i==n){ans.add(new ArrayList(arr));return;}for(int j=i;j<n;j++){if(dp[i][j]){arr.add(s.substring(i,j+1));dfs(j+1);arr.remove(arr.size()-1);}}}
}

51. N 皇后

一句话题意

        皇后的规则是可以吃相同行列、对角线的棋子,问所有满足可以在棋盘上防止N个互不影响的皇后。

一句话题解

        存三个set用于存哪个位置不能存,DFS即可。

class Solution {List<List<String>> ans = new ArrayList<>();List<String> arr = new ArrayList<>();Set<Integer> uy = new HashSet<>();Set<Integer> ul = new HashSet<>();Set<Integer> ur = new HashSet<>();int n;public List<List<String>> solveNQueens(int n) {this.n=n;dfs(0);return ans;}void dfs(int row){if(row==n){ans.add(new ArrayList<>(arr));return;}for(int i=0;i<n;i++){if(uy.contains(i)||ul.contains(row-i)||ur.contains(row+i))continue;StringBuffer s = new StringBuffer();for(int j=0;j<i;j++)s.append('.');s.append('Q');for(int j=i+1;j<n;j++)s.append('.');arr.add(new String(s));uy.add(i);ul.add(row-i);ur.add(row+i);dfs(row+1);uy.remove(i);ul.remove(row-i);ur.remove(row+i);arr.remove(arr.size()-1);}}
}

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

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

相关文章

pytest-前后置及fixture运用

1.pytest中的xunit风格前后置处理 pytest中用例的前后置可以直接使用类似于unittest中的前后置处理&#xff0c;但是pytest中的前后置处理方式更 加丰富&#xff0c;分为模块级、类级、方法级、函数级等不同等级的前后置处理&#xff0c;具体见下面的代码&#xff1a; test_…

使用scipy求解优化问题

一、求解二次规划问题 min(X.T * P * X C.T * X) s.t. Xi > 0 ∑Xi 1 1.定义目标函数 def objective(x):return 0.5 * np.dot(x, np.dot(P, x)) np.dot(c, x)2. 定义等式约束 def equality_constraint(x):return np.sum(x) - 1 3.定义边界约束&#xff1a;x # …

C++初阶-STL简介

目录 1.什么是STL 2.STL的版本 3.STL的六大组件 4.STL的重要性 4.1在笔试中 4.2在面试中 4.3.在公司中 5.如何学习STL 6.总结和之后的规划 1.什么是STL STL&#xff08;standard template library-标准模板库&#xff09;&#xff1b;是C标准库的重要组成部分&#xf…

kivy android打包buildozer.spec GUI配置

这个适合刚刚学习kivyd的道友使用&#xff0c;后面看情况更新 代码 import tkinter as tk from tkinter import ttk, filedialog, messagebox, simpledialog import configparser import os import json # 新增导入class BuildozerConfigTool:def __init__(self, master):se…

MOOS-ivp使用(一)——水下机器人系统的入门与使用

MOOS-ivp使用&#xff08;一&#xff09;——水下机器人系统的入门与使用 MOOS-ivp&#xff08;Marine Operational Oceanographic System for Intelligent Vehicle Planning&#xff09;是专为水下机器人&#xff08;如AUV&#xff09;设计的开源框架。类似于ROS&#xff0c;…

电子病历高质量语料库构建方法与架构项目(智能质控体系建设篇)

引言 随着人工智能技术的迅猛发展,医疗信息化建设正经历着前所未有的变革。电子病历作为医疗机构的核心数据资产,其质量直接关系到临床决策的准确性和医疗安全。传统的病历质控工作主要依赖人工审核,存在效率低下、主观性强、覆盖面有限等问题。近年来,基于人工智能技术的…

react学习笔记4——React UI组件库与redux

流行的开源React UI组件库 material-ui(国外) 官网: http://www.material-ui.com/#/github: GitHub - mui/material-ui: Material UI: Comprehensive React component library that implements Googles Material Design. Free forever. ant-design(国内蚂蚁金服) 官网: Ant…

GPU集群搭建

1. 硬件规划与采购 GPU 服务器&#xff1a;挑选契合需求的 GPU 服务器&#xff0c;像 NVIDIA DGX 系列就不错&#xff0c;它集成了多个高性能 GPU。网络设备&#xff1a;高速网络设备不可或缺&#xff0c;例如万兆以太网交换机或者 InfiniBand 交换机&#xff0c;以此保证节点…

ZYNQ 纯PL端逻辑资源程序固化流程

ZYNQ 纯PL端逻辑资源程序固化 ZYNQ的程序固化流程比传统的FPGA固化流程复杂很多&#xff0c;Vivado生成的bit文件无法直接固化在ZYNQ芯片中。因为ZYNQ 非易失性存储器的引脚&#xff08;如 SD 卡、QSPI Flash&#xff09;是 ZYNQ PS 部分的专用引脚。这些非易失性存储器由 PS …

[计算机科学#6]:从锁存器到内存,计算机存储的构建与原理

【核知坊】&#xff1a;释放青春想象&#xff0c;码动全新视野。 我们希望使用精简的信息传达知识的骨架&#xff0c;启发创造者开启创造之路&#xff01;&#xff01;&#xff01; 内容摘要&#xff1a;在上一篇文章中&#xff0c;我们深入了解了计算机如…

如何删除Google Chrome中的所有历史记录【一键清除】

谷歌浏览器记录了用户访问过的网站。这方便了查找&#xff0c;但有时也需要清理。删除所有历史记录很简单&#xff0c;只要按照以下步骤操作。 1. 打开谷歌浏览器 首先要启动谷歌浏览器。点击右上角的三个点&#xff0c;进入主菜单。 2. 进入历史记录界面 在菜单中找到“历史…

关于浏览器对于HTML实体编码,urlencode,Unicode解析

目录 HTML实体编码 URL编码 Unicode编码 解析层次逻辑 为什么<script></script>不可以编码符号 为什么不能编码JavaScript:协议 为什么RCDATA标签中的都会被解析成文本 为什么HTML编码了<>无法执行 HTML实体编码 通过特殊语法&#xff08;<、>…

【数据分享】2020年中国高精度森林覆盖数据集(免费获取)

森林作为全球陆地生态系统的主体&#xff0c;分布面积广、结构复杂&#xff0c;承担着调节气候、维护生态安全、改善环境等方面的重要作用。我国的森林资源丰富&#xff0c;据《中国森林资源报告&#xff1a;2014—2018》统计&#xff0c;我国森林覆盖率已经达到23.04%。森林覆…

C语言学习之动态内存的管理

学完前面的C语言内容后&#xff0c;我们之前给内存开辟空间的方式是这样的。 int val20; char arr[10]{0}; 我们发现这个方式有两个弊端&#xff1a;空间是固定的&#xff1b;同时在声明的时候必须指定数组的长度&#xff0c;一旦确定了大小就不能调整的。 而实际应用的过程中…

【深度学习-Day 2】图解线性代数:从标量到张量,理解深度学习的数据表示与运算

Langchain系列文章目录 01-玩转LangChain&#xff1a;从模型调用到Prompt模板与输出解析的完整指南 02-玩转 LangChain Memory 模块&#xff1a;四种记忆类型详解及应用场景全覆盖 03-全面掌握 LangChain&#xff1a;从核心链条构建到动态任务分配的实战指南 04-玩转 LangChai…

首页数据展示

排版 现在做首页的排版&#xff0c;依旧是偷antd里面的东西 使用card包裹list的样式 import React from react import axios import { Card, Col, Row, List } from antd import { EditOutlined, EllipsisOutlined, SettingOutlined } from ant-design/icons; import { Avat…

使用Set和Map解题思路

前言 Set和Map这两种数据结构,在解决一些题上&#xff0c;效率很高。跟大家简单分享一些题以及如何使用Set和Map去解决这些题目。 题目链接 136. 只出现一次的数字 - 力扣&#xff08;LeetCode&#xff09; 138. 随机链表的复制 - 力扣&#xff08;LeetCode&#xff09; 旧…

尝试leaflet+webassemly

前言 笔者在github发现rust版本的leaflet&#xff0c;发现是用wasm-bindgen包装的&#xff0c;尝试使用一下 Issues slowtec/leaflet-rshttps://github.com/slowtec/leaflet-rs 正文 准备 新建一个react项目&#xff0c;安装rsw依赖 pnpm i -D vite-plugin-rsw cargo ins…

机器学习实战,天猫双十一销量与中国人寿保费预测,使用多项式回归,梯度下降,EDA数据探索,弹性网络等技术

前言 很多同学学机器学习时总感觉&#xff1a;“公式推导我会&#xff0c;代码也能看懂&#xff0c;但自己从头做项目就懵”。 这次我们选了两个小数据集&#xff0c;降低复杂度&#xff0c;带大家从头开始进行分析&#xff0c;建模&#xff0c;预测&#xff0c;可视化等&…

SQL数据库系统全解析:从入门到实践

一、数据库世界入门指南 在数字时代&#xff0c;数据就像新时代的石油&#xff0c;而数据库系统就是储存和管理这些宝贵资源的仓库。对于初学者来说&#xff0c;理解数据库的基本概念是迈入这个领域的第一步。 数据库本质上是一个有组织的数据集合&#xff0c;它允许我们高效…