leetcode hot100 技巧

如有缺漏謬誤,還請批評指正。

1.只出現一次的數字

? ? ? ?利用異或運算相同得0的特點。所有出現過兩次的數字都會在異或運算累加過程中被抵消。

class Solution {
public:int singleNumber(vector<int>& nums) {int res=0;for(int i=0;i<nums.size();i++) res^=nums[i];return res;}
};

2.多數元素

? ? ? ? 隨機取數,然后判斷是否是答案。因為眾數被選中的概率大于50%,所以時間復雜度雖然理論上可能出現O(∞)的情況,但實際上可以達到O(n)。

class Solution {
public:int majorityElement(vector<int>& nums) {while(true){int candidate=nums[rand()%nums.size()];int count=0;for(int i=0;i<nums.size();i++){if(nums[i]==candidate){count++;if (count>nums.size()/2) return candidate;}}}return -1;}
};

3.顏色分類

????????經典的“荷蘭國旗”問題。

(1)單指針解法

class Solution {
public:void sortColors(vector<int>& nums) {int i=0;for(int j=0;j<nums.size();j++){if(nums[j]==0){swap(nums[i],nums[j]);i++;}}for(int j=i;j<nums.size();j++){if(nums[j]==1){swap(nums[i],nums[j]);i++;}}}
};

(2)雙指針解法

? ? ? ? 比單指針少了一趟遍歷。

①兩個同向指針分別記錄0的交換位置和1的交換位置。

class Solution {
public:void sortColors(vector<int>& nums) {int n=nums.size();int ptr0=0,ptr1=0;for(int i=0;i<n;i++){if(nums[i]==0){swap(nums[i],nums[ptr0++]);if(ptr1<ptr0) ptr1++;}if(nums[i]==1) swap(nums[i],nums[ptr1++]);}}
};

②左右指針分別記錄0的交換位置和2的交換位置。?

class Solution {
public:void sortColors(vector<int>& nums) {int n = nums.size();int r0=0,l2=n-1;  // r0: 0的右邊界,l2:2的左邊界for(int i=0;i<=l2;i++){       // 必須包含等于,因為nums[r]可能還沒處理if(nums[i]==0) swap(nums[i],nums[r0++]);  // 0交換到左邊,r0右移//換完后的理想狀態:換過后nums[i]是1(1處在0的右邊界和2的左邊界之間)else if(nums[i]==2){swap(nums[i],nums[l2--]);  // 2交換到右邊,l2左移if(nums[i]!=1) i--;  //num[i]==0的情況:2和0換,換過后的0需再換一遍到左邊界//num[i]==2的情況:2和2換,換過后的2需重新處理}}}
};

4.下一個排列

三個關鍵步驟:

  • 找到?i:i是第一個破壞從后向前升序的位置,這意味著nums[i]可以增大以得到更大的排列。

  • 找到?jnums[j]?是?i?之后比?nums[i]?大的最小數,交換后?nums[i]增大,但?i?之后的部分仍然降序。

  • 反轉:反轉?i+1之后的部分使其升序,這樣這部分最小,確保了整個排列是“下一個”排列。

class Solution {
public:void nextPermutation(vector<int>& nums) {int n=nums.size();int i=n-2;// 1. 找到第一個不符合逆序升的nums[i]while(i>=0&&nums[i]>=nums[i+1]) i--;// 2. 再找第一個比nums[i]大的nums[j],swap兩個數if(i>=0){int j=n-1;while(j>=0&&nums[j]<=nums[i]) j--;swap(nums[i], nums[j]);}// 3.反轉 i+1 到末尾的部分(使其升序)reverse(nums.begin()+i+1, nums.end());}
};

5.多數問題

核心思想:將數組視為鏈表,并利用快慢指針檢測環。

相遇的地點是環的入口(即重復數字):推導如下。

class Solution {
public:int findDuplicate(vector<int>& nums) {// 初始化快慢指針,初始位置在數組的起始位置(索引0)int slow=0,fast=0;// 第一階段:檢測環的存在(Floyd's Tortoise and Hare算法)do{slow=nums[slow];       // 慢指針每次移動一步fast=nums[nums[fast]]; // 快指針每次移動兩步} while (slow!=fast);      // 當快慢指針相遇時,說明存在環// 第二階段:找到環的入口(即重復的數字)slow=0; // 將慢指針重置到起點while(slow!=fast){slow=nums[slow]; // 慢指針每次移動一步fast=nums[fast]; // 快指針每次移動一步}// 最終相遇點就是重復的數字return slow;}
};

?

?

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

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

相關文章

git做commit信息時的校驗

親測可用&#xff01;不行你來打我&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 1. 文件基本信息 屬性說明文件名commit-msg&#xff08;必須無擴展名&#xff0c;如 .sh 或 .txt 會導致失效&#xff09;位置倉庫的 .git/hooks/ 目錄下&#xff08;或全局模…

4.9/Q1,GBD數據庫最新文章解讀

文章題目&#xff1a;The burden of diseases attributable to high body mass index in Asia from 1990 - 2019: results from the global burden of disease study 2019 DOI&#xff1a;10.1080/07853890.2025.2483977 中文標題&#xff1a;1990 年至 2019 年亞洲高體重指數導…

Activity動態切換Fragment

Activity 動態切換 Fragment 是 Android 開發中常見的需求&#xff0c;用于構建靈活的用戶界面。 以下是實現 Activity 動態切換 Fragment 的幾種方法&#xff0c;以及一些最佳實踐&#xff1a; 1. 使用 FragmentManager 和 FragmentTransaction (推薦) 這是最常用和推薦的方…

FreeRTOS Semaphore信號量-筆記

FreeRTOS Semaphore信號量-筆記 **一、信號量與互斥量的核心區別****二、二值信號量&#xff08;Binary Semaphore&#xff09;****1. 功能與使用場景****2. 示例&#xff1a;ADC中斷與任務同步** **三、計數信號量&#xff08;Counting Semaphore&#xff09;****1. 功能與使用…

音頻類網站或者資訊總結

我愛音頻網&#xff1a; 我愛音頻網 - 我們只談音頻&#xff0c;豐富的TWS真無線藍牙耳機拆解報告 (52audio.com) 其他更多資訊 音頻行業全品類深度剖析&#xff0c;2024市場趨勢解讀匯總-EDN 電子技術設計 (ednchina.com)

16.Excel:數據收集

一 使用在線協作工具 簡道云。 excel的在線表格協作在國內無法使用&#xff0c;而數據采集最需要在線協作。 二 使用 excel 1.制作表格 在使用excel進行數據采集的時候&#xff0c;會制作表頭給填寫人&#xff0c;最好還制作一個示例。 1.輸入提示 當點擊某個單元格的時候&am…

JAVA虛擬機(JVM)總結,很清晰,很好理解!!

目錄 java編譯相關知識 Java文件編譯過程 java的可跨平臺性 JVM內存結構 運行期數據區域&#xff08;JDK8之后&#xff09; 本地方法棧 虛擬方法棧 程序計數器 堆 本地內存 棧幀里面的局部變量表和方法區&#xff08;元空間的區別&#xff09; 類加載器 啟動類加載…

前端項目中單元測試與集成測試的管理實踐

前端項目中單元測試與集成測試的管理實踐 在現代前端工程化中&#xff0c;單元測試&#xff08;Unit Test&#xff09;和集成測試&#xff08;Integration Test&#xff09;已成為保障項目質量的重要手段。合理地組織和管理測試代碼&#xff0c;不僅有助于持續集成&#xff0c…

【Redis】緩存和分布式鎖

&#x1f525;個人主頁&#xff1a; 中草藥 &#x1f525;專欄&#xff1a;【中間件】企業級中間件剖析 一、緩存&#xff08;Cache&#xff09; 概述 Redis最主要的應用場景便是作為緩存。緩存&#xff08;Cache&#xff09;是一種用于存儲數據副本的技術或組件&#xff0c;…

深入解析路由策略:從流量控制到策略實施

一、網絡流量雙平面解析 在路由策略的設計中&#xff0c;必須明確區分兩個關鍵平面&#xff1a; 1. 控制層面&#xff08;Control Plane&#xff09; ??定義??&#xff1a;路由協議傳遞路由信息形成的邏輯平面&#xff08;如OSPF的LSA、RIP的Response報文&#xff09;?…

從杰夫?托爾納看 BPLG 公司的技術創新與發展

在科技與商業緊密交織的時代&#xff0c;企業的技術領導者在推動組織前行、應對復雜多變的市場環境中扮演著極為關鍵的角色。《對話 CTO&#xff0c;駕馭高科技浪潮》的第 6 章聚焦于杰夫?托爾納及其所在的 BPLG 公司&#xff0c;為我們展現了一幅技術驅動企業發展的生動圖景&…

UniRepLknet助力YOLOv8:高效特征提取與目標檢測性能優化

文章目錄 一、引言二、UniRepLknet 的框架原理&#xff08;一&#xff09;架構概述&#xff08;二&#xff09;架構優勢 三、UniRepLknet 在 YOLOv8 中的集成&#xff08;一&#xff09;集成方法&#xff08;二&#xff09;代碼實例 四、實驗與對比&#xff08;一&#xff09;對…

比較Facebook與其他社交平臺的隱私保護策略

在這個數字化的時代&#xff0c;隱私保護已成為用戶和社交平臺共同關注的核心議題。Facebook&#xff0c;作為全球最大的社交網絡平臺之一&#xff0c;其隱私保護策略一直受到廣泛的關注和討論。本文將對Facebook的隱私保護策略與其他社交平臺進行比較&#xff0c;以幫助用戶更…

數據結構--樹

一、樹的概念 樹是由n(n≥0)個節點組成的有限集合&#xff0c;它滿足以下條件&#xff1a; 1. 當n0時&#xff0c;稱為空樹 2. 當n>0時&#xff0c;有且僅有一個特定的節點稱為根節點(root) 3. 其余節點可分為m(m≥0)個互不相交的有限集合&#xff0c;每個集合本身又是一…

Linux `ifconfig` 指令深度解析與替代方案指南

Linux `ifconfig` 指令深度解析與替代方案指南 一、核心功能與現狀1. 基礎作用2. 版本適配二、基礎語法與常用操作1. 標準語法2. 常用操作速查顯示所有接口信息啟用/禁用接口配置IPv4地址修改MAC地址(臨時)三、高級配置技巧1. 虛擬接口創建2. MTU調整3. 多播配置4. ARP控制四…

什么是分布式光伏系統?屋頂分布式光伏如何并網?

政策窗口倒計時&#xff01;分布式光伏如何破局而立&#xff1f; 2025年&#xff0c;中國分布式光伏行業迎來關鍵轉折&#xff1a; ? "430"落幕——搶裝潮收官&#xff0c;但考驗才剛開始&#xff1b; ? "531"生死線——新增項目全面市場化交易啟動&…

Cluster Interconnect in Oracle RAC

Cluster Interconnect in Oracle RAC (文檔 ID 787420.1)?編輯轉到底部 In this Document Purpose Scope Details Physical Layout of the Private Interconnect Why Do We Need a Private Interconnect ? Interconnect Failure Interconnect High Availability Private Inte…

.Net HttpClient 使用準則

HttpClient 使用準則 System.Net.Http.HttpClient 類用于發送 HTTP 請求以及從 URI 所標識的資源接收 HTTP 響應。 HttpClient 實例是應用于該實例執行的所有請求的設置集合&#xff0c;每個實例使用自身的連接池&#xff0c;該池將其請求與其他請求隔離開來。 從 .NET Core …

【PostgreSQL】數據庫主從庫備份與高可用部署

文章目錄 一、架構設計原理二、部署清單示例2.1 StatefulSet配置片段2.2 Service配置三、配置詳解3.1 主節點postgresql.conf3.2 從節點配置四、初始化流程4.1 創建復制用戶4.2 配置pg_hba.conf五、故障轉移示例5.1 自動切換腳本5.2 手動提升從節點六、監控與維護6.1 關鍵監控指…

JavaScript 數組去重:11 種方法對比與實戰指南

文章目錄 前言一、使用 Set 數據結構二、使用 filter indexOf三、使用 reduce 累加器四、雙重 for 循環五、利用對象屬性唯一性六、先排序后去重七、使用 Map 數據結構八、使用 includes 方法九、優化處理 NaN 的 filter 方法十、利用 findIndex十一.利用Set和展開運算符處理多…