算法强化 —— 递归(回溯法)

这篇博客介绍了回溯法的概念及其在LeetCode中的应用,包括解决全排列问题(LeetCode 46题)和机器人运动范围问题。通过实例分析了如何使用回溯法来解决这些问题,强调了回溯法的递归模板和关键步骤,如判断节点访问、更新坐标、边界条件以及递归终止条件。
摘要由CSDN通过智能技术生成

回溯法

全排列问题
机器人的运动范围

LeetCode 46 全排列

给定一个没有重复数字的序列,返回其所有可能的全排列。
示例:
输入: [1,2,3]
输出:
[
[1,2,3],
[1,3,2],
[2,1,3],
[2,3,1],
[3,1,2],
[3,2,1]
]
什么是回溯法
1.递归一定会发生回溯
2.通常讲的回溯法师一种暴力的搜索方法



class Solution:
    def permute(self,nums):
        result_all = [] # 最终输出的结果
        visited = [0]*len(nums) # 定义一个数组 0 表示没有访问 1 表示访问过
        # n 表示当前走到哪一步
        # result 表示单词结果
        # result_all 表示最终的结果
        def dfs(n,nums,result):
            if n == len(nums):
                result_all.append(result[:])
                return
            for i in range(len(nums)):
                if visited
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值