Leetcode力扣秋招刷题路-0801

news2024/11/25 16:50:45

从0开始的秋招刷题路,记录下所刷每道题的题解,帮助自己回顾总结

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

我们有两个长度相等且不为空的整型数组 nums1 和 nums2 。在一次操作中,我们可以交换 nums1[i] 和 nums2[i]的元素。

例如,如果 nums1 = [1,2,3,8] , nums2 =[5,6,7,4] ,你可以交换 i = 3 处的元素,得到 nums1 =[1,2,3,4] 和 nums2 =[5,6,7,8] 。
返回 使 nums1 和 nums2 严格递增 所需操作的最小次数 。

数组 arr 严格递增 且 arr[0] < arr[1] < arr[2] < … < arr[arr.length - 1] 。

注意:

用例保证可以实现操作。

示例 1:
输入: nums1 = [1,3,5,4], nums2 = [1,2,3,7]
输出: 1
解释:
交换 A[3] 和 B[3] 后,两个数组如下:
A = [1, 3, 5, 7] , B = [1, 2, 3, 4]
两个数组均为严格递增的。

示例 2:
输入: nums1 = [0,3,5,8,9], nums2 = [2,1,4,6,9]
输出: 1

提示:
2 <= nums1.length <= 1 0 5 10^5 105
nums2.length == nums1.length
0 <= nums1[i], nums2[i] <= 2 ∗ 1 0 5 2 * 10^5 2105

方法一:动态规划
由于我们每次交换数字只需要和前一个数字进行比较,所以可以采用动态规划来解决。

条件①:nums1[i] > nums1[i - 1] && nums2[i] > nums2[i - 1]
条件②:nums1[i] > nums2[i - 1] && nums2[i] > nums1[i - 1]

若满足条件① && 满足条件②
在这里插入图片描述

交换和不交换都不影响递增,我们选择上一次的最小值,所以有

dp[i][0] = Math.min(dp[i - 1][0], dp[i - 1][1]);
dp[i][1] = Math.min(dp[i - 1][0], dp[i - 1][1]) + 1;

若满足条件① && 不满足条件②
在这里插入图片描述

若6和9交换则必须3和7也交换,才能保证递增,所以有

dp[i][0] = dp[i - 1][0]; 都不交换
dp[i][1] = dp[i - 1][1] + 1; 都交换

若不满足条件①
在这里插入图片描述

由于题中要求一定可以成功 如图,我们可以选择交换6和2或者3和7,所以有

dp[i][0] = dp[i - 1][1]; 上一次交换
dp[i][1] = dp[i - 1][0] + 1; 本次交换

public int minSwap(int[] nums1, int[] nums2) {
    int n = nums1.length;
    int[][] dp = new int[n][2];
    dp[0][0] = 0;
    dp[0][1] = 1;
    for (int i = 1; i < n; i++) {
        if (nums1[i] > nums1[i - 1] && nums2[i] > nums2[i - 1]) {
            //当前数字大于前一个数字
            if (nums1[i] > nums2[i - 1] && nums2[i] > nums1[i - 1]) {
                //当前数字大于另一个数组的前一个数字

                //前一个交换不交换都无所谓
                dp[i][0] = Math.min(dp[i - 1][0], dp[i - 1][1]);
                //交换 + 1
                dp[i][1] = Math.min(dp[i - 1][0], dp[i - 1][1]) + 1;
            } else {
                //当前数字不大于另一个数组的前一个数字

                //当前数字不交换,上一个也不能交换
                dp[i][0] = dp[i - 1][0];
                //当前数字交换,上一个也必须交换
                dp[i][1] = dp[i - 1][1] + 1;
            }
        } else {
            //当前数字不大于前一个数字

            //本次不交换 则上一次交换
            dp[i][0] = dp[i - 1][1];
            //本次交换 则上一次不交换
            dp[i][1] = dp[i - 1][0] + 1;
        }
    }
    return Math.min(dp[n - 1][0], dp[n - 1][1]);
}

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

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

相关文章

为什么越来越多的人开始学习大数据了?

现在&#xff0c;在数字化转型的推动下&#xff0c;越来越多的企业意识到大数据的魅力&#xff0c;并不断在这个领域投入资金&#xff0c;Python大数据开发相关人才也备受青睐&#xff01; 大数据从业领域很宽广&#xff0c;不管是科技领域还是食品产业&#xff0c;零售业等都…

大数据行业就业前景怎么样呢

就目前的前景来看&#xff0c;大数据的发展的确的非常不错的~ 既然回答大数据的问题&#xff0c;那就让我们到用数据的方式来回答一下。大数据需求越来越多&#xff0c;只有技术在手不愁找不到工作。 先来看几个招聘网站的报告数据&#xff1a;Boss直聘发布的&#xff0c;今年…

Zynq-7000、FMQL45T900的GPIO控制(七)---linux驱动层配置GPIO中断输入

本文使用的驱动代码 (1条消息) FMQL45T900linux驱动外部中断输入ZYNQ-7000linux驱动外部中断输入资源-CSDN文库 在Zynq-7000、FMQL45T900驱动层也时常会用到对GPIO的控制&#xff0c;这里就针对实际使用的情况进行说明&#xff0c;首先根据之前的帖子确实使用GPIO编号 这里采…

从不均匀性角度浅析AB实验 | 京东云技术团队

作者&#xff1a;京东零售 路卫强 本篇的目的是从三个不均匀性的角度,对AB实验进行一个认知的普及,最终着重讲述AB实验的一个普遍的问题&#xff0c;即实验准确度问题。 一、AB实验场景 在首页中&#xff0c;我们是用红色基调还是绿色基调&#xff0c;是采用门店小列表外商品…

C++ 探索程序 详细解读程序在运行过程中都发生了什么

目录 头文件-源代码 头文件重复包含 问题 解决方案 程序生成过程 预处理Preprocessi 编译Compilation 汇编Assembly 链接Linking 编译期-运行期 编译期确定 运行期确定 编译期错误 运行期错误 类和对象 宏 宏的其他用法 头文件-源代码 头文件&#xff08;.h&am…

Baklib分享:关于FAQ页面的一些制作技巧

FAQ页面&#xff08;Frequently Asked Questions&#xff09;是企业网站中常见的一种页面&#xff0c;主要用于解答客户常见的问题。一个优秀的FAQ页面不仅能够提高客户的满意度&#xff0c;还能够减轻客服部门的工作量。下面将介绍一些制作FAQ页面的技巧&#xff0c;并推荐使用…

Mysql使用函数后不走索引怎么优化?

网上很多人说mysql一旦使用函数就不走函数&#xff0c;但是事实真的是如此吗&#xff1f;我先说明&#xff0c;并不是如此的&#xff0c;本篇文章会通过DAYOFWEEK()和substr()两个函数作为条件查询&#xff0c;看看究竟是否会走索引&#xff08;其他函数同理&#xff09;&#…

15.基于主从博弈的智能小区代理商定价策略及电动汽车充电管理

说明书 MATLAB代码&#xff1a;基于主从博弈的智能小区代理商定价策略及电动汽车充电管理 关键词&#xff1a;电动汽车 主从博弈 动态定价 智能小区 充放电优化 参考文档&#xff1a;《基于主从博弈的智能小区代理商定价策略及电动汽车充电管理》基本复现 仿真平台&#…

【ChatGPT】如何修复access denied you do not have access to chat.openai.com

文章目录 一、前言二、是什么导致 ChatGPT 访问被拒绝错误&#xff1f;三、如何修复 OpenAI 上的访问被拒绝&#xff1f;3.1 清除 Cookies 和缓存3.2 检查账户登录凭证3.3 允许请求的权限3.4 从其他浏览器登录OpenAI3.5 联系 OpenAI 客户支持 四、ChatGPT 支持的国家和地区 一、…

delphi使用Edge Browser浏览器组件

RAD Studio 10.4在VCL Web浏览器上具有一项新功能。它是Edge Browser&#xff0c;它具有新功能&#xff0c;并且比以前的Web浏览器更具兼容性。 这是在C Builder和Delphi中使用Edge浏览器的快速帮助。 在Windows上安装“ Edge ”版本从RAD Studio的GetIt菜单下载“ Edge SDK…

JMeter的使用(二)

九、直连数据库 通过直连数据库让程序代替接口访问数据库&#xff0c;如果二者预期结果不一致&#xff0c;就找到了程序缺陷。 获取某条学院的名字&#xff0c;放在百度搜索: JMeter 不具备直连数据库功能&#xff0c;必须整合第三方(jar包)实现配置数据库的连接通过JDBC Re…

token 登录流程

客户端用账号密码请求登录服务端收到请求&#xff0c;验证账号密码验证成功后&#xff0c;服务端签发token&#xff0c;发送给客户端客户端收到token&#xff0c;保存下来客户端每次向服务器发送请求资源&#xff0c;都携带token服务器验证token验证成功&#xff0c;返回资源

LINUX文件管理与编辑命令2

文章目录 一、LINUX文件管理与编辑命令总结 一、LINUX文件管理与编辑命令 Linux wc命令:统计字节数、字数、行数 Linux echo命令:输出字符串或提取Shell变量的值 Linux chmod命令:权限管理 Linux chown命令:修改文件或目录的所有者或所属组 Linux whereis命令:查找文件 Linux …

揭秘长尾关键词的力量:如何在搜索引擎上挤掉竞争对手?

现在&#xff0c;你已经掌握了SEO 的流程&#xff0c;知晓了网站优化的各种方法&#xff0c;也清楚了站外优化的技巧&#xff0c;但问题又来了&#xff1a;你知道优化网站&#xff0c;竞争对手也知道&#xff1b;你懂得站外优化&#xff0c;竞争对手也懂。在这种情况下&#xf…

AI工具究竟是帮手还是对手?

本文概要 近日育碧开发了人工智能工具 Ghostwriter&#xff0c;可以一键生成游戏NPC对话。不少游戏开发者担心AI写手工具的出现会让自己“饭碗”不保&#xff0c;但Swanson表示这个工具只是为了提供第一稿的 barks来减少对话生成工作的繁琐度。AI工具究竟是帮手还是对手&#x…

C++笔试笔记1(4399 西山居 深信服 剑心互娱 快手)

写在前头&#xff0c;这里面只是我在做这些公司笔试时抄下来的一部分题&#xff0c;并不全&#xff0c;但我会尽量把我所抄的每道题的知识点都贴上 1. Linux下支持的IO多路复用&#xff0c;有selec、poll和epoll&#xff0c;但Windows下仅支持select。 2. 新版C&#xff0c;智…

OpenGL(一)——初识和搭建

目录 一、前言 二、概述 2.1 光学 2.2 三通道 2.3 上下文Context 2.4 渲染管线 2.5 着色器Shader 2.6 缓冲区和数组 三、安装 四、运行 五、库API 5.1 核心库GL 5.2 实用库GLUT 一、前言 渲染render是用软件从模型生成图像的过程&#xff0c;也表示编辑视频生成想达…

2023年第二十届五一数学建模竞赛题目 B题超详细思路

详细思路以及发布视频版&#xff0c;大家可以去观看&#xff0c;这里是对应的文字版&#xff0c;内容相差不多。 B题&#xff1a;快递需求分析问题 B题的问题难度不大&#xff0c;难点就在于后几问的模型求解。问题多、模型多、冗杂&#xff0c;就是B题的特点。 难度 A>B…

代码随想录训练营day56|583、两个字符串的删除操作;72、编辑距离;编辑距离总结篇

583、两个字符串的删除操作 给定两个单词 word1 和 word2&#xff0c;找到使得 word1 和 word2 相同所需的最小步数&#xff0c;每步可以删除任意一个字符串中的一个字符。 示例&#xff1a; 输入: "sea", "eat"输出: 2解释: 第一步将"sea"变…

vue3之vite创建h5项目1(创建vite项目、配置IP访问项目、配置多环境变量与预览打包生产效果、配置别名)

目录 vue3之vite创建h5项目101&#xff1a;创建vite项目02&#xff1a;配置IP访问项目 vite.config.ts03&#xff1a;配置多环境变量03-1&#xff1a;配置多环境变量之dev环境 .env.development03-2&#xff1a;配置多环境变量之test环境 .env.test03-3&#xff1a;配置多环境变…