前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >”回溯算法“框架及练习题

”回溯算法“框架及练习题

原创
作者头像
刘大猫
发布于 2024-11-01 06:49:41
发布于 2024-11-01 06:49:41
870
举报
文章被收录于专栏:算法题算法题

@toc

一、回溯算法是什么?

结论:==回溯 = 穷举==

解决一个回溯问题,实际上就是一个决策树的遍历过程

  1. 路径:就是已经做出的选择
  2. 选择列表:就是你当前可以做出的选择
  3. 结束条件:就是base case条件,也就是临界条件

二、框架如下:

==框架如下:==

代码语言:java
AI代码解释
复制
result = []
def backtrack(路径,选择列表) {
	if 满足结束条件 : 
		result.add(路径)
		return
	for 选择 in 选择列表
		做选择
		backtrack(路径,选择列表)
		撤销选择	
}

==举例:经典回溯算法问题:全排列问题==

代码语言:java
AI代码解释
复制
public class TestNode {
	private static List<List<Integer>> res = new LinkedList<>();

	public static void main(String[] args){
			//问题2.1:全排列问题
	        permute(new int[]{1,2,3});
	        res.stream().forEach(item -> System.out.print(item + " "));
	}	
代码语言:java
AI代码解释
复制
	/**
     * 问题2.1:全排列问题,输入一个数组,输出所有全排列顺序
     *      框架:路径:记录在track中
     *           选择列表:nums中不存在于track的那些元素
     *           结束条件:nums中元素全部在track中出现
     * @param nums 数组
     * @return list
     */
    public static List<List<Integer>> permute(int[] nums) {
        //记录“路径”
        LinkedList<Integer> track = new LinkedList<>();
        backtrack(nums, track);
        return res;
    }
    public static void backtrack(int[] nums, LinkedList<Integer> track) {
        //base case
        if (track.size() == nums.length) {
            res.add(new LinkedList<>(track));
            return;
        }
        for (int i = 0; i < nums.length; i++) {
            //排除不合法的选择
            if (track.contains(nums[i])) continue;
            //做选择
            track.add(nums[i]);
            //进入下一层决策树
            backtrack(nums, track);
            //取消选择
            track.removeLast();
        }
    }

==输出结果==

代码语言:java
AI代码解释
复制
[1, 2, 3] [1, 3, 2] [2, 1, 3] [2, 3, 1] [3, 1, 2] [3, 2, 1] 

本人其他文章链接

1.单链表题+数组题(快慢指针和左右指针)

2.BFS(Breath First Search 广度优先搜索)

3.”回溯算法“框架及练习题

4.JAVA 二叉树面试题

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
回溯算法
如果你不理解这三个词语的解释,没关系,我们后面会用「全排列」和「N 皇后问题」这两个经典的回溯算法问题来帮你理解这些词语是什么意思,现在你先留着印象。
麋鹿大哥
2020/08/19
5930
回溯算法详解(修订版)
这篇文章是很久之前的一篇《回溯算法详解》的进阶版,之前那篇不够清楚,就不必看了,看这篇就行。把框架给你讲清楚,你会发现回溯算法问题都是一个套路。
labuladong
2021/09/23
4550
回溯算法团灭排列/组合/子集问题
今天就来聊三道考察频率高,而且容易让人搞混的算法问题,分别是求子集(subset),求排列(permutation),求组合(combination)。这几个问题都可以用回溯算法解决。
lucifer210
2020/02/26
1.6K0
一文秒杀排列组合问题的 9 种题型
虽然这几个问题是高中就学过的,但如果想编写算法决这几类问题,还是非常考验计算机思维的,本文就讲讲编程解决这几个问题的核心思路,以后再有什么变体,你也能手到擒来,以不变应万变。
labuladong
2022/03/30
1.4K0
一文秒杀排列组合问题的 9 种题型
球盒模型:一切回溯穷举,皆从此法出
阅读本文之前,需要你熟悉 回溯算法核心框架 以及 回溯算法秒杀排列/组合/子集问题。
labuladong
2024/04/10
2140
球盒模型:一切回溯穷举,皆从此法出
算法学习记录
一、介绍 1、常见的数据结构 「队列」、「栈」这两种数据结构既可以使⽤链表也可以使⽤数组实现。⽤数组实现,就要处理扩容缩容的问题;⽤链表实现,没有这个问题,但需要更多的内存空间存储节点指针。 「图」的两种表⽰⽅法,邻接表就是链表,邻接矩阵就是⼆维数组。邻接矩阵判断连通性迅速,并可以进⾏矩阵运算解决⼀些问题,但是如果图⽐较稀疏的话很耗费空间。邻接表⽐较节省空间,但是很多操作的效率上肯定⽐不过邻接矩阵。 「散列表」就是通过散列函数把键映射到⼀个⼤数组⾥。⽽且对于解决散列冲突的⽅法,拉链法需要链表特性,操作
MiChong
2020/11/17
4620
高频面试系列:单词拆分问题
读完本文,可以去力扣解决如下题目: 139. 单词拆分(中等) 140. 单词拆分II(困难)
labuladong
2022/09/01
6970
高频面试系列:单词拆分问题
面试必备:回溯算法详解
我们刷leetcode的时候,经常会遇到回溯算法类型题目。回溯算法是五大基本算法之一,一般大厂也喜欢问。今天跟大家一起来学习回溯算法的套路,文章如果有不正确的地方,欢迎大家指出哈,感谢感谢~
捡田螺的小男孩
2022/02/10
6490
面试必备:回溯算法详解
算法系列之回溯算法
在计算机科学领域,算法是解决问题的核心。回溯算法作为一种经典的算法设计技巧,以其试错和回退的思想,在解决许多复杂问题时展现出强大的能力。本文将深入探讨回溯算法,包括其核心概念、实现步骤、代码示例以及适用场景,帮助读者更好地理解和应用这一算法。
修己xj
2025/03/12
2530
算法系列之回溯算法
回溯算法
【举例 1】 全排列问题: 给定一个没有重复数字的序列,返回其所有可能的全排列。
范中豪
2022/05/10
3710
回溯算法
我的刷题经验总结
两年前刚开这个公众号的时候,我写了一篇 学习数据结构和算法的框架思维,现在已经 5w 多阅读了,这对于一篇纯技术文来说是很牛逼的数据。
labuladong
2021/10/14
8050
LeetCode通关:连刷十四题,回溯算法完全攻略
例如我们在查找二叉树所有路径的时候,查找完一个路径之后,还需要回退,接着找下一个路径。
三分恶
2021/09/23
1K0
LeetCode通关:连刷十四题,回溯算法完全攻略
力扣78题-子集
力扣78. 子集 题目描述: 给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 示例 1: 输入:nums = [1,2,3] 输出:[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]] 示例 2: 输入:nums = [0] 输出:[[],[0]] 提示: 1 <= nums.length <= 10 -10 <= nums[i] <= 10 nums 中的
ccf19881030
2023/02/26
2120
力扣78题-子集
数据结构和算法学习指南
这篇文章会涵盖之前的所有内容,并且会举很多代码的实例,谈谈如何使用框架思维,并且给对于算法无从下手的朋友给一点具体可执行的刷题建议。
五分钟学算法
2020/02/24
7220
回溯/贪心高频题
"有关递归的算法,都离不开“树”的遍历这一抽象模型。只不过对于不同的算法,在前(中)后序遍历的时候,所做的事不同而已。 "
王脸小
2019/10/28
1.4K0
【愚公系列】2023年12月 五大常用算法(二)-回溯算法
回溯算法的基本思想是在搜索过程中,对每个可能的步骤都尝试一遍,如果该步骤不行,则回溯到上一步,尝试其他可能的步骤,直到找到解决问题的方案。回溯算法通常用于解决搜索和优化问题,如数独游戏、全排列、组合、子集、棋盘问题等。
愚公搬代码
2023/12/13
3191
小白易懂的回溯算法!!!
1.什么是回溯算法? 回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。回溯法是一种选优搜索法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,这种走不通就退回再走的技术为回溯法,而满足回溯条件的某个状态的点称为“回溯点”。许多复杂的,规模较大的问题都可以使用回溯法,有“通用解题方法”的美称。 回溯算法解题套路模板: 1.回溯出口,当找到了一个问题的解时,存储该解。 2
大忽悠爱学习
2021/11/15
6860
Python 算法基础篇:回溯算法的原理与应用
回溯算法是一种经典的算法技术,它在解决组合、排列、子集和图问题等方面表现出色。本篇博客将详细解释回溯算法的原理,探讨回溯算法的应用,并通过实例代码演示它在问题求解中的灵活运用。
小蓝枣
2023/07/24
9090
回溯算法在项目中的实际应用
大多数同学苦于刷了很多算法却在项目中很少应用,难以加深印象,而且总有同学问着有啥用啊有啥用啊?为了刷题而刷题,带着需求场景去应用算法是最为直接的学习方式。
疯狂的KK
2022/04/14
6760
回溯算法在项目中的实际应用
从全排列看回溯算法
最近又刷起了算法,仿佛回到了大一时奋战到深夜场景,走上社会之初发现大学里学的都是啥玩意儿,工作中基本遇不到,各种数据结构都被封装的妥妥的根本不需要我们去操心,以至于越来越浮于表面。
sealyun
2020/02/11
7940
从全排列看回溯算法
相关推荐
回溯算法
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档