首页 > 其他分享 >801. 使序列递增的最小交换次数

801. 使序列递增的最小交换次数

时间:2022-10-10 11:47:13浏览次数:48  
标签:min 递增 a1 b1 b2 序列 801 nums1 nums2

题目描述

给了两个整型数组nums1和nums2,数组长度相等且不为空,定义了一个操作:可以交换两个数组中同索引的元素
如果要使nums1和nums2严格递增,问最小的操作次数?(用例保证可以实现操作)

基本分析

  1. 严格递增的定义?不包含等号
  2. 什么情况下需要交换?是不是两个数组中有一个会碰到一个逆序的,统计逆序的个数就行?不行,有可能a1<a2, b1<b2的时候也会交换;而交换前的状态会影响交换后的状态
  3. 严格递增包含了其他啥信息?只用考虑相邻元素的关系->可以从左到右递推关系,只不过不能只看逆序这么简单
  4. 单纯考虑逆序不行,应该怎么做?增加一个维度,用dp来做。具体怎么实现?
    • 状态定义上怎么考虑?除了前i个元素i这个维度外,还要考虑i处元素是不是交换这个事情,再定义一个新的维度,值为0或者1,dp[i][0]表示不交换i处的元素时,前i个元素严格递增的最小操作次数,dp[i][1]表示交换i处的元素时,前一个元素严格递增的最小操作次数
    • 转移上怎么考虑?因为只用考虑相邻关系,用a1、a2,b1,b2分别表示nums1[i-1], nums1[i], nums2[i-1]
      , nums2[i]。会有以下情况:
      • a1<a2, b1<b2 这个时候可换可不换。不换时有f[i][0]=f[i-1][0], 换时有f[i][1]=f[i-1][1]+1, 注意这里的换是同时进行变换
      • b1<a2, a1<b2 这个时候可以交换其中一对。前一个位置交换:f[i][0] = f[i-1][1], 后一个位置交换f[i][1] = f[i-1][0]+1
      • 同时满足以上情况的时候,要取最小值

代码

f1-原始定义状态机dp
class Solution:
    def minSwap(self, nums1: List[int], nums2: List[int]) -> int:
        n = len(nums1)
        f = [[inf, inf] for _ in range(n)]
        f[0] = [0, 1]
        for i in range(1, n):
            a1, a2 = nums1[i-1], nums1[i]
            b1, b2 = nums2[i-1], nums2[i]
            if a1 < a2 and b1 < b2:
                f[i][0] = f[i-1][0]
                f[i][1] = f[i-1][1] + 1
            if a1 < b2 and b1 < a2:
                f[i][0] = min(f[i][0], f[i-1][1])
                f[i][1] = min(f[i][1], f[i-1][0] + 1)
        
        return min(f[-1])
f2-优化空间
class Solution:
    def minSwap(self, nums1: List[int], nums2: List[int]) -> int:
        n = len(nums1)
        f = [[0, 1], [inf, inf]]
        
        for i in range(n):
            ns, s = inf, inf
            a1, a2, b1, b2 = nums1[i-1], nums1[i], nums2[i-1], nums2[i]
            prev, cur = (i-1)&1, i&1
            if a1 < a2 and b1 < b2:
                ns, s = f[prev][0], f[prev][1]+1
            if a1 < b2 and b1 < a2:
                ns, s = min(ns, f[prev][1]), min(s, f[prev][0]+1)
            f[cur][0], f[cur][1] = ns, s
        
        return min(f[(n-1)&1][0], f[(n-1)&1][1])

复杂度

时间:n是数组长度,需要遍历两个数组一次,为\(O(n)\)
空间:如果使用滚动数组,是常量空间\(O(1)\)

总结

  1. 题意和逆序的关系?(1)不是只有逆序才能换,比如[1,3], [2,4]可以换成[2,4],[1,3]
  2. 严格递增给的信息?直观相邻元素关系就行,可以递推去做
  3. 考虑到dp递推去做的时候,需要考虑哪些维度?一个是i,前i个元素的交换状态;另外需要扩充一个维度,表示i的位置换不换。
  4. 可以交换的情况有哪些?(1)a1<a2, b1<b2可以换0或者2次,(2)a1<b2, b1<a2, 可以换1次
  5. 两种可换的情况还需要特别考虑什么?可能都能满足,需要第二种可能时候取min
  6. 优化空间的算法是怎么优化?外侧定义f的时候i取两个维度就行,在每次遍历时候初始化一个局部的结果,利用(i-1)&1, i&1拿到索引prev和cur,处理完以后把局部结果赋值给f[cur], 最终的结果是f[(n-1)&1]

标签:min,递增,a1,b1,b2,序列,801,nums1,nums2
From: https://www.cnblogs.com/zk-icewall/p/16775098.html

相关文章

  • 代码随想录 day18|513. 找树左下角的值 112. 路径总和 113. 路径总和 II 105. 从前序
    513.找树左下角的值题目|文章1.前序遍历思路题目的要求是先是最底层最左边的节点的值,我们使用前序遍历可以保证是最左边的值,通过深度变化时对节点更新,可以保证是最底......
  • 2022年10个用于时间序列分析的Python库推荐
    时间序列是数据点的序列,通常由在一段时间间隔内进行的连续测量组成。时间序列分析是使用统计技术对时间序列数据进行建模和分析,以便从中提取有意义的信息并做出预测的过程......
  • ThinkPHP6.0.13反序列化漏洞分析
    1. 前言最近有点闲下来了,不找点事干比较难受,打算找点漏洞分析一下,于是就打算看看TP的一些漏洞,ThinkPHP6.0.13是TP的最新版,八月份有师傅提交了一个issue指出TP存在反序列......
  • rust md5 sha1 sha256 sha512序列化
    [dependencies]rust-crypto="0.2.36"md5usecrypto::md5::Md5;usecrypto::digest::Digest;fnmain(){letmuthasher=Md5::new();lettext=String::from("12......
  • Python学习实验报告03——序列
    实验要求:完成课本实例部分及实战部分实验内容:Part1实例:实例01:创建一个文件命名为tips,导入日期时间类,定义一个包含七条励志文字的列表,获取当前星期作为索引输出每日一......
  • java序列化
    一、序列化与反序列化序列化:指堆内存中的java对象数据,通过某种方式把对存储到磁盘文件中,或者传递给其他网络节点(网络传输)。这个过程称为序列化,通常是指将数据结构或对象转......
  • 接收前端参数(反序列化) 学习
    参考:https://www.bilibili.com/video/BV1XR4y157rk?p=6&spm_id_from=pageDriver&vd_source=caabcbd2a759a67e2a3de8acbaaf08ea针对模型字段和属性见https://blog.csdn.......
  • 对象的序列化与反序列化
    ObjectOutputStream对象序列化流作用:把对象以流的形式写入道文件中保存构造方法:ObjectOutputStream(OutputStreamout)特有的方法:voidwriteObject(Objectobj)将......
  • 37.序列化器关系类型字段
    关系字段用于表示模型之间的关联Django中存在ForeignKey、MantToManyField和OneToOneField三种正向关系,以及反向关联和自定义关联当继承ModelSerializer类的时候,包括关......
  • leetcode 106. Construct Binary Tree from Inorder and Postorder Traversal 从中序
    一、题目大意给定两个整数数组inorder和postorder,其中inorder是二叉树的中序遍历,postorder是同一棵树的后序遍历,请你构造并返回这颗二叉树。示例1:输入:ino......