LeetCode 滑動數組統計+至少 2962. 統計最大元素出現至少 K 次的子數組

2962. 統計最大元素出現至少 K 次的子數組

給你一個整數數組 nums 和一個 正整數 k 。
請你統計有多少滿足 「 nums 中的 最大 元素」至少出現 k 次的子數組,并返回滿足這一條件的子數組的數目。
子數組是數組中的一個連續元素序列。
示例 1:
輸入:nums = [1,3,2,3,3], k = 2
輸出:6
解釋:包含元素 3 至少 2 次的子數組為:[1,3,2,3]、[1,3,2,3,3]、[3,2,3]、[3,2,3,3]、[2,3,3] 和 [3,3] 。
示例 2:
輸入:nums = [1,4,2,1], k = 3
輸出:0
解釋:沒有子數組包含元素 4 至少 3 次。
提示:
1 <= nums.length <= 105
1 <= nums[i] <= 106
1 <= k <= 105

題解

如標題所示,本題采用滑動數組進行解題

題目要求所有滿足條件的子數組
那么我們自然需要考慮所有的子數組
我們該如何做到呢

首先看看如何枚舉所有的子數組
我們可以用一個循環枚舉出所有子數組可能的開頭,然后內層再寫一個循環枚舉所有可能的結尾,這樣就枚舉了所有的子數組

那么滑動數組又該如何考慮到所有的子數組呢?


類似的,我們可以寫一個循環枚舉出所有子數組的結尾 i
然后使用指針 l=0 作為子數組的開頭,那么 l 與 i 就是滑動窗口的區間
我們使用變量 count 記錄滑動窗口中的最大值的個數,res=0 記錄返回值
此時 i 作為窗口的右邊不斷右移
當 count == k 時,此時的滑動窗口滿足條件,我們找到了一個答案

但是問題是,接下來我們要如移動滑動窗口呢?
將 i 向右移,還是將 l 向右移

注意到,我們第一層循環是枚舉所有子數組的結尾
只要對于每一種結尾,我們都找到所有可能的子數組就能解決問題
但是我們顯然不能枚舉開頭 l ,否則與枚舉就一樣了,時間復雜高
當 count == k 時,我們可以將 窗口左邊 l 右移,直到 count != k
那么對于此時的 i ,此時所有以 l 的左邊為開頭的子數組 [ l, i ] 都是滿足條件的
也就是我們找到了以 i 結尾的所有滿足條件的子數組
所以滑動窗口 [ l, i ] 的含義就是以 i 結尾的,第一個不滿足條件的子數組
res+=l ,枚舉下一個 i
如果 count != k,那么 l 的位置不變,res+=l
如果count==k,那么接著移動 l 直到滑動窗口不滿足條件

總計滑動窗口劃過一次數組,時間復雜度為 O(n)


代碼如下↓

long long countSubarrays(int* nums, int numsSize, int k) {int l=0;int max=0;long res=0;int count=0;for(int i=0;i<numsSize;i++){if(nums[i]>max){max=nums[i];}}for(int i=0;i<numsSize;i++){if(nums[i]==max){count++;}while(count==k)//怎么說呢,每次i就是子數組的右端點,每次當count的個數為k的時候,就將l右移,直到count<k,那么l之前的所有字符都可以作為子數組的左端點,也就是說以i為右端點的滿足條件的子數組有left個。然后i繼續右移,直到count再次==k,然后重復以上過程,left左邊的所有字符同樣滿足條件,count的個數肯定>=k,所以res+=left{if(nums[l]==max){count--;}l++;}res+=l;printf("%d\n",l);}return res;
}

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

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

相關文章

FANUC機器人幾種常用的通訊網絡及接口

FANUC機器人幾種常用的通訊網絡及接口 Devicenet 網絡通訊接口&#xff0c;接口為5針線 (規定用的機架為 81-84&#xff09; PROFIBUS 網絡通訊接口&#xff0c;針腳為2針&#xff08;規定用的機架為 67&#xff09; Intemet 網絡通訊接口&#xff08;常用的網線接口&#xf…

CentOS8+Zabbix7.2.4解決中文顯示問題

#cd /usr/share/zabbix/ui/include/ #grep graphfont defines.inc.php define(‘ZBX_GRAPH_FONT_NAME’, ‘graphfont’); // font file name define(‘ZBX_FONT_NAME’, ‘graphfont’); #ll /usr/share/zabbix/ui/assets/fonts/graphfont.ttf lrwxrwxrwx. 1 root root 36 3…

AI自動化編程初探

先說vscodeclinemodelscope方案&#xff0c;后面體驗trae或者cursor再寫寫其它的。vscode和trae方案目前來說是免費的&#xff0c;cursor要用claud需要付費&#xff0c;而且不便宜&#xff0c;當然效果可能是最好的。 vscode方案&#xff0c;我的經驗是最好在ubuntu上&#xff…

101.在 Vue 3 + OpenLayers 使用 declutter 避免文字標簽重疊

1. 前言 在使用 OpenLayers 進行地圖開發時&#xff0c;我們經常需要在地圖上添加點、線、區域等圖形&#xff0c;并給它們附加文字標簽。但當地圖上的標注較多時&#xff0c;文字標簽可能會發生重疊&#xff0c;導致用戶無法清晰地查看地圖信息。 幸運的是&#xff0c;OpenL…

18天 - 常見的 HTTP 狀態碼有哪些?HTTP 請求包含哪些內容,請求頭和請求體有哪些類型?HTTP 中 GET 和 POST 的區別是什么?

常見的 HTTP 狀態碼有哪些&#xff1f; HTTP 狀態碼用于指示服務器對客戶端請求的響應結果&#xff0c;常見的 HTTP 狀態碼可以分為以下幾類&#xff1a; 1. 信息類&#xff08;1xx&#xff09; 100 Continue&#xff1a;客戶端應繼續發送請求。101 Switching Protocols&…

IXTUR氣控永磁鐵:以高精度氣控和穩定磁場,為機器人應用提供穩定抓取力

在現代工業生產和物流領域&#xff0c;物料的抓取與搬運是影響生產效率和成本控制的重要環節。傳統夾爪在面對不同材質、形狀和重量的物體時&#xff0c;常常存在適應性差、抓取不穩定、操作復雜等問題&#xff0c;導致生產流程中頻繁出現停機調整&#xff0c;增加了人工干預成…

江科大51單片機筆記【16】AD/DA轉換(下)

寫在前言 此為博主自學江科大51單片機&#xff08;B站&#xff09;的筆記&#xff0c;方便后續重溫知識 在后面的章節中&#xff0c;為了防止篇幅過長和易于查找&#xff0c;我把一個小節分成兩部分來發&#xff0c;上章節主要是關于本節課的硬件介紹、電路圖、原理圖等理論知識…

【C++】 —— 筆試刷題day_4

刷題day_4 繼續加油&#xff01;&#xff01;&#xff01; 一、Fibonacci數列 題目鏈接&#xff1a;Fibonacci數列 題目解析 題目要求&#xff0c;輸入一個數N&#xff0c;我們可以對N進行1/-1操作&#xff1b;題目讓我們輸出對N進行至少多少步可以變成Fibonacci數。 這里題目…

IP層之分片包的整合處理---BUG修復

在之前章節中&#xff0c;筆者就IP層之分片包的整合處理進行了概念介紹&#xff0c;以及代碼編寫和仿真&#xff0c;在整體代碼調試環節&#xff0c;筆者發現了一個問題&#xff0c;在本文中&#xff0c;筆者將就這個BUG進行說明&#xff0c;以及進行修復&#xff0c;講解代碼實…

修復Electron項目Insecure Content-Security-Policy(內容安全策略CSP)警告的問題

將以下代碼粘貼進html的<header>標簽內 <metahttp-equiv"Content-Security-Policy"content"default-src self; style-src self unsafe-inline; img-src self data:; "> 解釋一下上面代碼中的屬性含義 default-src self&#xff1a;配置加載策…

linux 的免密切換用戶PAM配置

/etc/pam.d/su是Linux系統中與用戶切換&#xff08;su命令&#xff09;相關的PAM&#xff08;Pluggable Authentication Modules&#xff0c;可插拔認證模塊&#xff09;配置文件。以下是對它的詳細介紹&#xff1a; 簡介 作用 PAM是一種用于管理系統認證的機制&#xff0c;…

pyspark 數據處理的三種方式RDD、DataFrame、Spark SQL案例

目錄 一、淺語二、三種數據處理方式比較2.1 RDD2.2 DataFrame2.3 Spark SQL 三、三種方法的創建方式3.1 創建RDD3.2 創建DataFrame3.2.1 創建sqlContext3.2.2 定義Schema3.2.3 創建DataFrame 3.3 創建SparkSQL3.3.1 登錄臨時表3.3.2 使用sparkSQL 四、三種方法顯示部分字段4.1 …

文件解析漏洞靶機---- 練習通關攻略

1.安裝靶機 點擊 hackme.ova 文件&#xff0c;直接導入虛擬機&#xff0c;選擇存儲位置 2. 開啟靶機 3. kali掃描同C段的ip&#xff0c;找到靶機ip nmap 192.168.182.1/24 經判斷&#xff0c;靶機ip為&#xff1a;192.168.182.157 開啟端口 http 80 、ssh 遠程連接 22 4…

信號處理抽取多項濾波的數學推導與仿真

昨天的《信號處理之插值、抽取與多項濾波》&#xff0c;已經介紹了插值抽取的多項濾率&#xff0c;今天詳細介紹多項濾波的數學推導&#xff0c;并附上實戰仿真代碼。 一、數學變換推導 1. 多相分解的核心思想 將FIR濾波器的系數 h ( n ) h(n) h(n)按相位分組&#xff0c;每…

【大模型基礎_毛玉仁】2.3 基于 Encoder-only 架構的大語言模型

更多內容&#xff1a;XiaoJ的知識星球 目錄 2.3 基于Encoder-only 架構的大語言模型2.3.1 Encoder-only 架構2.3.2 BERT 語言模型1&#xff09;BERT 模型結構2&#xff09;BERT 預訓練方式3&#xff09;BERT 下游任務 2.3.3 BERT 衍生語言模型1&#xff09;RoBERTa 語言模型2&a…

AIP-165 按條件刪除

編號165原文鏈接https://google.aip.dev/165狀態批準創建日期2019-12-18更新日期2019-12-18 有時API需要提供一種機制&#xff0c;按照一些過濾參數刪除大量資源&#xff0c;而非提供待刪除的各資源名字。 這是一個稀有的場景&#xff0c;用于用戶一次性刪除數千或更多資源的…

【Maven教程與實戰案例】

文章目錄 前言一、Maven是什么&#xff1f;二、Maven的安裝與配置1. 安裝前置條件2. 下載與配置 Maven3. 驗證安裝 三、Maven的核心概念1. POM.xml 文件2. 構建生命周期與插件機制 四、實戰項目示例1. 項目目錄結構2. 編寫代碼App.javaAppTest.java 3. 構建項目4. 運行項目 前言…

20250310:OpenCV mat對象與base64互轉

代碼: https://github.com/ReneNyffenegger/cpp-base64 指南:https://renenyffenegger.ch/notes/development/Base64/Encoding-and-decoding-base-64-with-cpp/ 實操:

概率論的基本知識

逆概率還不懂&#xff0c;改天再想想。 聯合概率 聯合概率&#xff08;Joint Probability&#xff09; 是概率論中的一個重要概念&#xff0c;用于描述多個隨機變量同時取某些值的概率。聯合概率可以幫助我們理解多個變量之間的關系。

pytest數據庫測試文章推薦

參考鏈接&#xff1a; 第一部分&#xff1a;http://alextechrants.blogspot.fi/2013/08/unit-testing-sqlalchemy-apps.html第二部分&#xff1a;http://alextechrants.blogspot.fi/2014/01/unit-testing-sqlalchemy-apps-part-2.html