算法打卡day25

今日任务:

1)491.递增子序列

2)46.全排列

3)47.全排列 II

491.递增子序列

题目链接:491. 非递减子序列 - 力扣(LeetCode)

给定一个整型数组, 你的任务是找到所有该数组的递增子序列,递增子序列的长度至少是2。
示例:
输入: [4, 6, 7, 7]
输出: [[4, 6], [4, 7], [4, 6, 7], [4, 6, 7, 7], [6, 7], [6, 7, 7], [7,7], [4,7,7]]

说明:
给定数组的长度不会超过15。
数组中的整数范围是 [-100,100]。
给定数组中可能包含重复数字,相等的数字应该被视为递增的一种情况

文章讲解:代码随想录 (programmercarl.com)

视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列哔哩哔哩bilibili

思路:

  1. 使用回溯算法,遍历数组中的每个元素。
  2. 对于当前元素,尝试将其加入当前子序列中,然后递归地向后探索更长的子序列。
  3. 在向后探索过程中,需要进行剪枝操作,以排除重复的结果和不满足递增条件的情况。
  4. 当遍历完所有可能的情况时,将满足要求的子序列加入结果列表中

 下面是一个错误代码

class Solution:
    def findSubsequences(self, nums: List[int]) -> List[List[int]]:
        self.result = []
        self.backtrack(nums, 0, [])
        return self.result

    def backtrack(self, nums, start, path):
        # 如果当前路径长度大于1,则将该路径加入结果列表中
        if len(path) > 1:
            self.result.append(path[:])

        # 遍历数组中从start索引开始的所有元素
        for i in range(start, len(nums)):
            # 剪枝条件1:如果当前元素与前面的元素相同,则跳过,避免重复结果
            if i > start and nums[i] in nums[:i]:
                continue

            # 剪枝条件2:如果当前元素小于路径中的最后一个元素,跳过,确保生成的子序列是递增的
            if not path or nums[i] >= path[-1]:
                # 递归
                path.append(nums[i])
                self.backtrack(nums, i + 1, path)
                path.pop()

在第一个剪枝部分,不能直接去用当前nums[i]与数组之前的部分判断重复,这样是判断当前元素是否出现在路径中
这样导致的我们找的子集是没有重复元素的,但[1,2,1,1]这种是符合要求的,所以这样剪枝是错的
而是应该判断当前层,元素nums[i]是否遍历过 

46.全排列

题目链接:46. 全排列 - 力扣(LeetCode)

给定一个 没有重复 数字的序列,返回其所有可能的全排列。

示例:
输入: [1,2,3]
输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ]

文章讲解:代码随想录 (programmercarl.com)

视频讲解:组合与排列的区别,回溯算法求解的时候,有何不同?| LeetCode:46.全排列哔哩哔哩bilibili

思路:

使用回溯算法来生成全排列。
维护一个结果列表 result 来存储所有可能的全排列。
回溯函数 backtrack 的参数包括当前要排列的数组 nums 和当前已生成的部分排列 path。
在回溯函数中,首先判断是否满足终止条件,即 path 的长度是否等于 nums 的长度,如果满足则将 path 加入 result 中。
然后遍历数组 nums 中的每个元素,如果该元素已经在 path 中,则跳过,否则将其加入 path 中,递归调用回溯函数,完成后需要撤销选择,以便尝试其他未选择的元素。

class Solution:
    def permute(self, nums: List[int]) -> List[List[int]]:
        self.result = []
        self.backtrack(nums, [])
        return self.result

    def backtrack(self, nums, path):
        # 当遍历完时,path长度等于原数组长度
        if len(path) == len(nums):
            self.result.append(path[:])

        for i in range(len(nums)):
            # 剪枝:如果当前元素已经遍历则跳过
            if nums[i] in path:
                continue

            # 递归层
            path.append(nums[i])
            self.backtrack(nums, path)
            path.pop()

感想:

这题比较简单,递归遍历时,起始位置与之前的不一样,这次从头遍历

47.全排列 II

题目链接:47. 全排列 II - 力扣(LeetCode)

给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列。

示例 1:
输入:nums = [1,1,2]
输出: [[1,1,2], [1,2,1], [2,1,1]]

示例 2:
输入:nums = [1,2,3]
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

提示:
1 <= nums.length <= 8
-10 <= nums[i] <= 10

文章讲解:代码随想录 (programmercarl.com)

视频讲解:回溯算法求解全排列,如何去重?| LeetCode:47.全排列 II哔哩哔哩bilibili

思路:

1)使用回溯算法来生成全排列。
2)首先对原数组进行排序,这样重复元素会相邻,方便后续剪枝操作。
3)回溯函数 backtrack 的参数包括当前要排列的数组 nums、当前已生成的部分排列 path 和一个数组 used,用于记录每个数字是否已被使用。
4)在回溯函数中,首先判断是否满足终止条件,即 path 的长度是否等于 nums 的长度,如果满足则将 path 加入 result 中。
5)然后遍历数组 nums 中的每个元素,如果该元素已经被使用过,则跳过,否则标记该元素为已使用,选择当前元素并递归调用回溯函数,完成后需要撤销选择,并将当前元素标记为未使用,以便尝试其他未选择的元素。

class Solution:
    def permuteUnique(self, nums: List[int]) -> List[List[int]]:
        nums.sort()
        self.result = []
        self.backtrack(nums, [], [False] * len(nums))
        return self.result

    def backtrack(self, nums, path,used):
        # 终止条件:当路径长度等于原数组长度时,表示已经生成了一个全排列
        if len(path) == len(nums):
            self.result.append(path[:])

        for i in range(len(nums)):
            # 剪枝:如果当前元素已经遍历则跳过
            if used[i]:
                continue
            # 剪枝:同一层不能重复取相同的数字,若前一个相同数字未被使用,则跳过当前数字
            if i > 0 and nums[i] == nums[i - 1] and used[i-1] == False:
                continue

            used[i] = True # 标记当前元素已被使用

            # 递归层
            path.append(nums[i])
            self.backtrack(nums, path,used)
            path.pop()
            used[i] = False

感想:

这一题有两个剪枝,第一个是每一个树层上,也就是同一级的for循环上,如果有重复的,我们就不用继续了,因为第一个元素出现时就已经涵盖所有可能性。我们可以对数组排序,然后比较当前nums[i]是否等于前一个,还需要补充的限制是,前一个已经遍历过了
第二个剪枝就是与上一题一样的,每一个树枝上已经使用的放进path中的就跳过

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

选数异或(DP)

题目描述 给定一个长度为 n 的数列 A1, A2, , An 和一个非负整数 x&#xff0c;给定 m 次查询, 每次询问能否从某个区间 [l,r] 中选择两个数使得他们的异或等于 x 。 输入格式 输入的第一行包含三个整数 n, m, x 。 第二行包含 n 个整数 A1, A2, , An 。 接下来 m 行…

Redis高可用技术

一.Redis高可用介绍&#xff1a; 高可用是指&#xff1a;服务器正常访问的时间 衡量的标准是&#xff1a;在多长时间内可以提供正常服务99.9%、99.99%、99.999%等等 但是在Redis语境中&#xff0c; 高可用的含义似乎要宽泛一些&#xff0c;除了保证提供正常服务(如主从分离、…

Find a way (DFS BFS)

//新生训练 #include <iostream> #include <algorithm> #include <queue> using namespace std; using PII pair<int, int>;const int N 205; const int inf 0x3f3f3f3f; int n, m; int l;int dis1[N][N]; int dis2[N][N];int dx[] {0, 0, -1, 1};…

springboot实战---6.项目发布

&#x1f388;个人主页&#xff1a;靓仔很忙i &#x1f4bb;B 站主页&#xff1a;&#x1f449;B站&#x1f448; &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;Springboot &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&…

深入C语言:探究static关键字的奥秘

文章目录 一、链接属性二、static变量1、定义静态局部变量2、在函数内部使用静态变量3、函数中静态局部变量与递归 三、static变量与全局变量的区别1、存储期与生命周期2、可见性与作用域3、使用场景4、静态与动态内存分配 注意事项 当用于不同的上下文环境时&#xff0c; sta…

nginx配置多vue项目

1. 找到linux docker安装好的nginx目录文件 进入nginx内 把打包好的vue项目放在html文件下 如上 三个文件夹下对应着三个不同的vue项目 2. 配置default.conf的配置文件&#xff0c; 一个nginx配置文件可以多个项目进行代理 进入到conf 找到conf.d下面的default.conf 文件…

Springboot自动获取接口实现

ServiceLoader加载接口实现步骤 1.编写接口 public interface CommunicationAdapterFactory {void setKernel(LocalKernel kernel);boolean providesAdapterFor(Vehicle vehicle);BasicCommunicationAdapter getAdapterFor(Vehicle vehicle); }2.编写实现 // 实现类 1 publi…

EasyBoss ERP支持TikTok Shop拆单发货功能,多店铺订单包裹拆分一个系统搞定

一些TikTok Shop本土卖家在运营过程中面临这样的困境&#xff1a;当顾客一次性订购多个商品&#xff0c;由于部分商品缺货或包裹超重&#xff0c;订单延迟发货或被物流限制发不出货&#xff0c;导致店铺被投诉。为了解决这一问题&#xff0c;卖家可以采取拆单发货的策略&#x…

支持各种不同系列nvdia显卡和amd显卡,DeepFaceLab安装与使用,附完整的软件打包下载一键安装

支持各种不同系列nvdia显卡和amd显卡&#xff0c;DeepFaceLab安装与使用&#xff0c;附完整的软件打包下载一键安装。 主要使用的技术&#xff1a; 1. 深度学习&#xff08;Deep Learning&#xff09; 深度学习是人工智能领域的一个重要分支&#xff0c;它通过模拟人脑的神经…

蓝桥杯 - 正则问题

解题思路&#xff1a; dfs import java.util.Scanner;public class Main {static int pos -1; // 充当charAt下标static String s;// 字符串型的静态变量public static void main(String[] args) {Scanner scanner new Scanner(System.in);s scanner.nextLine();System.ou…

Spring Boot--文件上传和下载

文件上传和下载 前言文件上传1、以MultipartFile 接口流文件&#xff0c;流的名称需要和前台传过来的名称对应上2、获取到文件名称截取后缀3、为了放置文件名重复使用uuid来随机生成id后缀4、判断转存路径中是否有这个文件夹如果没有就创建5、将文件存储到转存的目录中 文件下载…

免费AI视频工具PixVerse厉害了:可保持人物超强一致性(附详细教程)

PixVerse 上线了「Character」&#xff0c;可以在更换场景的情况下&#xff0c;保持人物的一致性。 下面就是用创建的人物角色&#xff0c;生成的不同场景下&#xff08;海边、城市街道、教室&#xff09;的视频&#xff0c;整体看一致性程度还是超出我的预期的。 PixVerse 人物…

华为服务器RAID配置教程 服务器硬盘故障处理帮助 浪潮RAID配置教程 磁盘阵列配置通用教程

前言&#xff08;本文档持续更新&#xff09; 本文主要记录服务器配置RAID&#xff08;磁盘阵列&#xff09;过程中存在的细节问题及官方文档无法解决的问题的解决方案 配置环境 华为 RH2288 v3服务器配置RAID组 如何快速配置 1.找到服务器品牌的阵列卡型号&#xff0c;找不到…

DBU-Net:用于乳腺超声图像中肿瘤分割的双分支U形网络

DBU-Net&#xff1a;用于乳腺超声图像中肿瘤分割的双分支U形网络 摘要引言材料和方法概述所提出的方法 DBU-Net Dual branch U-Net for tumor segmentation in breast ultrasound images 摘要 乳腺超声医学图像通常具有低成像质量沿着不清楚的目标边界。这些问题使得医生在诊断…

详解k8s集群内外的访问方式

文章目录 1、集群内访问2、集群外访问2.1、Ingress转发外网请求2.2、LoadBanlancer接入外网请求2.3、NodePort接入外网请求 3、总结和对比3.1、Ingress、NodePort和LoadBalancer总结3.2、Ingress和网关的区别 1、集群内访问 在k8s中创建的微服务&#xff0c;大部分都是在集群内…

收下这份地表最强参会指南,4月16日,玩转百度Create大会不迷路

欢迎来到英杰社区&#xff1a; https://bbs.csdn.net/topics/617804998 欢迎来到阿Q社区&#xff1a; https://bbs.csdn.net/topics/617897397 &#x1f4d5;作者简介&#xff1a;热爱跑步的恒川&#xff0c;致力于C/C、Java、Python等多编程语言&#xff0c;热爱跑步&#xff…

短视频素材怎么做?探索新鲜网站获取灵感

在短视频创作的过程中&#xff0c;寻找和制作高质量的素材是至关重要的。那么&#xff0c;短视频素材怎么做呢&#xff1f;让我们一起探索一些新鲜的网站&#xff0c;获取灵感和素材&#xff0c;让你的短视频作品更加别出心裁&#xff01; 蛙学网——中国 国内首推荐蛙学网&a…

dm控制台工具console

DM控制台工具console console工具介绍 DM控制台工具是管理和维护数据库的基本工具。 通过使用控制台工具&#xff0c;数据库管理员可以完成以下功能: ◆服务器参数配置 ◆管理DM服务 ◆脱机备份与还原 ◆查看系统信息 ◆查看许可证信息 一 登录console [dmdbatest1 tool]$ pwd…

3.java openCV4.x 入门-数据类型(CvType)与Scalar

专栏简介 &#x1f492;个人主页 &#x1f4f0;专栏目录 点击上方查看更多内容 &#x1f4d6;心灵鸡汤&#x1f4d6;我们唯一拥有的就是今天&#xff0c;唯一能把握的也是今天 &#x1f9ed;文章导航&#x1f9ed; ⬆️ 2.hello openCV ⬇️ 4.待更新 数据类型&#xff…

【算法】字典序超详细解析(让你有一种相见恨晚的感觉!)

目录 一、前言 二、什么是字典序 &#xff1f; ✨字典序概念 ✨深度理解字典序 ✨字典序排序的重要性和应用场景 三、常考面试题 ✨ 下一个排列 ✨ 字典数排序 ✨ 字典序最小回文串 四、共勉 一、前言 经常刷算法题的朋友&#xff0c;肯定会经常看到题目中提到 字典序 这样…