leetcode2934. 最大化數組末位元素的最少操作次數-medium

1 題目:最大化數組末位元素的最少操作次數

官方標定難度:中

給你兩個下標從 0 開始的整數數組 nums1 和 nums2 ,這兩個數組的長度都是 n 。

你可以執行一系列 操作(可能不執行)。

在每次操作中,你可以選擇一個在范圍 [0, n - 1] 內的下標 i ,并交換 nums1[i] 和 nums2[i] 的值。

你的任務是找到滿足以下條件所需的 最小 操作次數:

nums1[n - 1] 等于 nums1 中所有元素的 最大值 ,即 nums1[n - 1] = max(nums1[0], nums1[1], …, nums1[n - 1]) 。
nums2[n - 1] 等于 nums2 中所有元素的 最大值 ,即 nums2[n - 1] = max(nums2[0], nums2[1], …, nums2[n - 1]) 。
以整數形式,表示并返回滿足上述 全部 條件所需的 最小 操作次數,如果無法同時滿足兩個條件,則返回 -1 。

示例 1:

輸入:nums1 = [1,2,7],nums2 = [4,5,3]
輸出:1
解釋:在這個示例中,可以選擇下標 i = 2 執行一次操作。
交換 nums1[2] 和 nums2[2] 的值,nums1 變為 [1,2,3] ,nums2 變為 [4,5,7] 。
同時滿足兩個條件。
可以證明,需要執行的最小操作次數為 1 。
因此,答案是 1 。

示例 2:

輸入:nums1 = [2,3,4,5,9],nums2 = [8,8,4,4,4]
輸出:2
解釋:在這個示例中,可以執行以下操作:
首先,選擇下標 i = 4 執行操作。
交換 nums1[4] 和 nums2[4] 的值,nums1 變為 [2,3,4,5,4] ,nums2 變為 [8,8,4,4,9] 。
然后,選擇下標 i = 3 執行操作。
交換 nums1[3] 和 nums2[3] 的值,nums1 變為 [2,3,4,4,4] ,nums2 變為 [8,8,4,5,9] 。
同時滿足兩個條件。
可以證明,需要執行的最小操作次數為 2 。
因此,答案是 2 。

示例 3:

輸入:nums1 = [1,5,4],nums2 = [2,5,3]
輸出:-1
解釋:在這個示例中,無法同時滿足兩個條件。
因此,答案是 -1 。

提示:

1 <= n == nums1.length == nums2.length <= 1000
1 < = n u m s 1 [ i ] < = 1 0 9 1 <= nums1[i] <= 10^9 1<=nums1[i]<=109
1 < = n u m s 2 [ i ] < = 1 0 9 1 <= nums2[i] <= 10^9 1<=nums2[i]<=109

2 solution

 1 設 nums1, nums2 最后一個數分別是 x 和 y,則它們必須滿足是全局最大值和最小值的最大值2 不妨設 x = min(x, y) 則可以統計各數組中有幾個數比 x 大

代碼

class Solution {/** 1 設 nums1, nums2最后一個數分別是 n1 和 n2,則它們必須滿足是全局最大值和最小值的最大值* 2 不妨設 x = min(n1, n2) 則可以統計各數組中有幾個數比 x 大*/
public:int minOperations(vector<int> &nums1, vector<int> &nums2) {int x = nums1.back();int y = nums2.back();if (x > y) swap(x, y);int a = 0, b = 0;for (int i = 0; i < nums1.size() - 1; i++) {if (nums1[i] > y || nums2[i] > y) return -1;if (nums1[i] > x && nums2[i] > x) return -1;if (nums1[i] > x) a++;else if (nums2[i] > x) b++;}if (x == y) return min(a, b);if (x == nums1.back()) return min(a, b + 1);return min(a + 1, b);}
};

結果

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/81317.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/81317.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/81317.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Elasticsearch 官網閱讀之 Term-level Queries

Term-level Queries 參考&#xff1a;https://www.elastic.co/docs/reference/query-languages/query-dsl/query-dsl-exists-query 一、Term Query Term Query 是 term 精準查詢。需要注意的是&#xff0c;在進行 Term Query 的時候&#xff0c;要避免 text 類型的字段&#x…

信貸域——互聯網金融業務

摘要 本文深入探討了信貸域全托與半托業務的定義、特點、適用場景及注意事項&#xff0c;并分析了互聯網金融核心信息流的多個方面&#xff0c;包括資金流、信息流、風險流、合規流、物流、技術流和商流&#xff0c;還闡述了金融系統“斷直連”業務的相關內容&#xff0c;以及…

科技晚報 AI 速遞:今日科技熱點一覽 丨 2025 年 5 月 17 日

科技晚報AI速遞:今日科技熱點一覽 丨2025年5月17日 我們為您匯總今日的科技領域最新動向&#xff0c;帶您快速了解前沿技術、突破性研究及行業趨勢。 黃仁勛勸特朗普&#xff1a;AI 芯片出口規則得改&#xff0c;中國緊追其后&#xff1a;英偉達 CEO 黃仁勛在華盛頓 “山與谷論…

使用streamlit實現vLLM多實例信息統一監控

本文代碼和配置文件實現了一個基于 Streamlit 和 FastAPI 的前后端分離的應用程序&#xff0c;用于管理和展示 VLLM&#xff08;Very Large Language Model&#xff09;實例的信息。以下是代碼和配置文件的總結摘要&#xff1a; 概要 功能概述 前后端啟動方式&#xff1a; 使用…

搭建一個WordPress網站需要多少成本

WordPress 最初可能只是一個簡單的博客平臺。但近年來&#xff0c;它不僅成為了最好的博客平臺&#xff0c;還成為了一個全面的內容管理系統。白宮、jQuery、NGINX、《紐約時報》等企業都把 WordPress 作為自己的網上家園。 不過&#xff0c;它們只是其中的佼佼者。根據 Built…

飛帆控件 post or get it when it has get

我在這里分享兩個鏈接&#xff1a; post_get_it 設計 - 飛帆 有人看出來這個控件是干什么用嗎&#xff1f; 控件的配置&#xff1a;

AI智能體 | 使用Coze一鍵制作“假如書籍會說話”視頻,18個作品狂吸17.6萬粉,讀書博主新標桿!(附保姆級教程)

目錄 一、整體工作流設計 二、制作工作流 2.1 開始節點 2.2 大模型_生成對話文案 2.3 代碼_字幕切割 2.4 畫板_對話背景 2.5 循環_對話語音01 2.5.1 選擇器_2 2.5.2 語音合成02 2.5.3 語音合成03 2.5.4 變量聚合_1 2.5.5 視頻合成01 2.6 循環_3 2.6.1 選擇器_3 …

mysql中4種掃描方式和聚簇索引非聚簇索引【爽文一篇】

目錄 一 mysql的聚簇索引&非聚簇索引 1.1 數據表 1.2 聚簇索引 1.3 非聚簇索引 1.4 覆蓋索引 二 mysql的4種掃描查詢 2.1 全表掃描 2.2 索引掃描 2.3 覆蓋索引掃描 2.4 回表掃描 2.5 總結 三 mysql的回表查詢詳解 3.1 回表查詢 一 mysql的聚簇索引&非聚簇…

泛微對接金蝶云星空實戰案例技術分享

前言 在企業信息化建設中&#xff0c;OA系統與ERP系統對接往往是一個復雜而關鍵的環節。OA系統通常具有高度的自定義性&#xff0c;其基礎資料和單據可能與ERP系統存在字段不一致等問題。同時&#xff0c;OA系統涉及審批流程及流程發起方定義&#xff0c;增加了對接的復雜性。…

一種資源有限單片機處理cJSON數據的方法

一般單片機處理cJSON格式的數據都直接使用cJSON庫&#xff0c;但對于Ram較小的單片機&#xff0c;由于資源有限&#xff0c;這并不合適&#xff0c;但我們可以根據cJSON數據的特定格式&#xff0c;使用土方法&#xff0c;直接對字符進行查找裁剪即可 //截取字符串str中字符a與…

關于軟件測試開發的一些有趣的知識

文章目錄 一、什么是測試&#xff1f;二、為什么要軟件測試軟件測試三、測試的崗位有哪些四 、軟件測試和開發的區別五、走測試崗位為什么還要學開發。4、優秀的測試人員具備的素質我為什么走測試崗位 一、什么是測試&#xff1f; 其實這個問題說簡單也不簡單&#xff0c;說難…

【C++ 基礎數論】質數判斷

質數判斷 質數&#xff1a;對于所有大于 1 的自然數而言&#xff0c;如果該數除 1 和自身以外沒有其它因數 / 約數&#xff0c;則該數被稱為為質數&#xff0c;質數也叫素數。 如何判定一個數是否為質數呢&#xff1f; 一個簡單的方法是 試除法 &#xff1a; 對于一個數 n&…

6to4、6over4的類比解釋

本文由deepseek生成&#xff0c;特此聲明 1. 6to4&#xff1a;自動的“快遞中轉站” 類比場景&#xff1a; 假設你住在一個偏遠的小鎮&#xff08;IPv6網絡&#xff09;&#xff0c;周圍被大海&#xff08;IPv4互聯網&#xff09;包圍&#xff0c;你想給另一個偏遠小鎮&#…

數字化工廠升級引擎:Modbus TCP轉Profinet網關助力打造柔性生產系統

在當今的工業自動化領域&#xff0c;通信協議扮演著至關重要的角色。Modbus TCP和Profinet是兩種廣泛使用的工業通信協議&#xff0c;它們分別在不同的應用場景中發揮著重要作用。然而&#xff0c;有時我們可能需要將這兩種協議進行轉換&#xff0c;以實現不同設備之間的無縫通…

計算機網絡-MPLS LDP基礎實驗配置

前面我們學習了LDP的會話建立、標簽發布與交換、LDP的工作原理&#xff0c;今天通過一個基礎實驗來加深記憶。 一、LDP基礎實驗 實驗拓撲&#xff1a; 1、IGP使用OSPF進行通告&#xff0c;使用Lookback接口作為LSR ID&#xff0c;LDP ID自動生成。 2、實驗目的&#xff1a;使…

Ocean: Object-aware Anchor-free Tracking

領域&#xff1a;Object tracking It aims to infer the location of an arbitrary target in a video sequence, given only its location in the first frame 問題/現象&#xff1a; Anchor-based Siamese trackers have achieved remarkable advancements in accuracy, yet…

[Java] 方法和數組

目錄 1. 方法 1.2 什么是方法 1.2 方法的定義 1.3 方法的調用 1.4 方法的重載 1.5 遞歸 2. 一維數組 2.1 什么是數組 2.2 數組的創建 2.3 數組的初始化 2.4 遍歷數組 2.5 引用數據類型 2.6 關于null 2.7 數組轉字符串 2.8 數組元素的查找 2.9 數組的排序 2.10…

全局異常處理:如何優雅地統一管理業務異常

在軟件開發中&#xff0c;異常處理是保證系統健壯性的重要環節。一個良好的異常處理機制不僅能提高代碼的可維護性&#xff0c;還能為使用者提供清晰的錯誤反饋。本文將介紹如何通過全局異常處理和業務異常統一處理來編寫更加優雅的代碼。 一、傳統異常處理的痛點 1.1 典型問…

PHP 編程:現代 Web 開發的基石與演進

引言 PHP&#xff08;Hypertext Preprocessor&#xff09;自1995年誕生以來&#xff0c;已成為全球最流行的服務器端腳本語言之一。盡管近年來Node.js、Python等語言在特定領域嶄露頭角&#xff0c;但PHP仍占據著超過78%的網站市場份額&#xff08;W3Techs數據&#xff09;。本…

MCU程序加密保護(一)閃存讀寫保護法 加密與解密

MCU&#xff08;微控制器單元&#xff09;的加密方法可以從硬件、軟件和通信協議三個層面來理解。以下是常見的MCU加密手段&#xff0c;按類型分類說明&#xff1a; 針對目前 STM32 系列微控制器在程序加密保護方面手段單一、保護效果有限的問題&#xff0c;本文介紹并分析了四…