每日算法【雙指針算法】(Day 1-移動零)

雙指針算法

  • 1.算法題目(移動零)
  • 2.講解算法原理
  • 3.編寫代碼

1.算法題目(移動零)

在這里插入圖片描述

2.講解算法原理

數組劃分,數組分塊(快排里面最核心的一步)只需把0改為tmp
在這里插入圖片描述
雙指針算法:利用數組下標來充當指針

兩個指針的作用:
cur:從做往右掃描數組,遍歷數組
dest:已處理的區間內,非零元素的最后一個位置

在這里插入圖片描述
三個區間:
[0,dest] ,[dest+1,cur-1] , [cur,n-1]
按序依次是非0,0,待處理

  • 當cur=n時 變成

在這里插入圖片描述
在這里插入圖片描述
先讓dest指向下標為-1的位置,cur指向下標為0的元素,此時元素為0,cur++,cur指向的元素為1,這時dest++,然后交換dest和cur指向的元素,也就是交換0和1的位置。
總結:cur從前往后遍歷的過程中

  1. 遇到0元素:cur++
  2. 遇到非0元素:
swap(dest+1,cur);
dest++,cur++;

3.編寫代碼

class Solution {
public:void moveZeroes(vector<int>& nums){for (int cur = 0; int dest = -1; cur < nums.size(); cur++)if (nums[cur])//處理非零元素swap(nums[++dest], nums[cur]);}
};

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

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

相關文章

SQL Server 的鎖機制

SQL Server 的鎖機制是為了確保數據的一致性和事務的隔離性而設計的。以下是針對讀寫操作的鎖定行為的詳細說明&#xff1a; 1. 鎖的基本類型 SQL Server 的鎖主要分為以下幾類&#xff1a; 共享鎖&#xff08;Shared Lock, S Lock&#xff09; 用於讀操作&#xff08;如 S…

AIP目錄

專注于開發靈活API的設計文檔。 AIP是總結了谷歌API設計決策的設計文檔&#xff0c;它也為其他人提供了用文檔記錄API設計規則和實踐的框架和系統。 基礎1AIP目的和指南2AIP編號規則3AIP版本管理200先例8AIP風格與指導9術語表流程100API設計評審常見問題205Beta版本發布前置條…

CSS進度條帶斑馬紋動畫(有效果圖)

效果圖 .wxml <view class"tb"><view class"tb-line" style"transform:translateX({{w%}})" /> </view> <button bind:tap"updateLine">增加進度</button>.js Page({data: {w:0,},updateLine(){this.…

【工具-Krillin AI】視頻翻譯、配音、語音克隆于一體的一站式視頻多語言轉換工具~

Krillin AI 是全能型音視頻本地化與增強解決工具。這款簡約而強大的工具&#xff0c;集音視頻翻譯、配音、語音克隆于一身&#xff0c;支持橫豎屏格式輸出&#xff0c;確保在所有主流平臺&#xff08;嗶哩嗶哩&#xff0c;小紅書&#xff0c;抖音&#xff0c;視頻號&#xff0c…

zset.

zset 有序集合 zset 保留了 set 不能有重復元素的特點 zset 中的每個元素都有一個唯一的浮點類型的分數&#xff08;score&#xff09;與之關聯&#xff0c;使得 zset 內部的元素是可以維護有序性的。但是這個有序不是用下標作為排序依據的&#xff0c;而是根據分數&#xf…

Spring 數據庫編程

Spring JDBC 傳統的JDBC在操作數據庫時&#xff0c;需要先打開數據庫連接&#xff0c;執行SQL語句&#xff0c;然后封裝結果&#xff0c;最后關閉數據庫連接等資源。頻繁的數據庫操作會產生大量的重復代碼&#xff0c;造成代碼冗余&#xff0c;Spring的JDBC模塊負責數據庫資源…

492Q 型氣缸蓋雙端面銑削組合銑床總體設計

一、引言 492Q 型氣缸蓋是發動機的重要組成部分&#xff0c;其雙端面的加工精度對發動機的性能和可靠性有著重要影響。設計一款適用于 492Q 型氣缸蓋雙端面銑削的組合銑床&#xff0c;能夠提高加工效率和質量&#xff0c;滿足發動機生產的需求。 二、總體設計要求 加工精度&…

顎式破碎機的設計

一、引言 顎式破碎機作為礦山、建材等行業的重要破碎設備&#xff0c;其性能優劣直接影響物料破碎效率與質量。隨著工業生產規模的擴大和對破碎效率要求的提高&#xff0c;設計一款高效、穩定、節能的顎式破碎機具有重要意義。 二、設計需求分析 處理能力&#xff1a;根據目…

第三階段面試題

Nginx nginx常用模塊以及其功能 proxy模塊&#xff0c;進行代理功能 ssl模塊&#xff0c;進行HTTPS協議的使用 gzip模塊&#xff0c;進行傳輸數據的壓縮 upstream模塊&#xff0c;進行反向代理時使用 static模塊&#xff0c;靜態資源進行訪問的模塊 cache模塊&#xff0…

鴻蒙NEXT開發鍵盤工具類(ArkTs)

export declare type KeyboardCallBack (show: boolean, height: number) > void; import { AppUtil } from ./AppUtil; import { LogUtil } from ./LogUtil; import { ArrayUtil } from ./ArrayUtil;/*** 鍵盤工具類* author 鴻蒙布道師* since 2025/04/18*/ export class…

基于 LabVIEW 的電液伺服閥測試臺開發

開發了一種基于 LabVIEW 圖形編程語言的自動測試系統&#xff0c;能夠完成電液伺服閥的空載流量特性、壓力增益特性、內泄漏特性等靜態特性的自動測試。針對測試過程中干擾信號頻段與正常信號頻段接近&#xff0c;普通數字濾波器濾波效果不佳的問題&#xff0c;采用迭代濾波分解…

【uniapp】vue2 使用 Vuex 狀態管理

創建store文件夾&#xff1a;store/index.js // index.js import Vue from vue import Vuex from vuex import address from ./modules/address.jsVue.use(Vuex)const store new Vuex.Store({modules: {address} })export default store 創建modules文件夾&#xff1a;modul…

c# 簡單實現將Message的內容保存到txt中,超過100個則清理舊文件

using System; using System.IO; using System.Threading;public static class LogManager {private static readonly object _fileLock new object(); // 線程安全鎖private const int MaxFiles 100; // 最大文件數限制private const string LogDire…

阿里云鏡像加速僅支持阿里云產品了

最近在拉取docker鏡像時一直報超時的錯誤&#xff1a; docker pull hello-world Using default tag: latest Error response from daemon: Get "https://registry-1.docker.io/v2/": net/http: request canceled while waiting for connection (Client.Timeout exce…

從零實現Git安裝、使用

一、git安裝 Git官方下載 1.下載exe程序 2.雙擊安裝&#xff0c;一直點擊next&#xff0c;默認安裝 安裝完成后&#xff0c;在任意文件夾右鍵&#xff0c;出現下圖所示&#xff0c;即為安裝成功。 3.【Git Bash Here】調出命令窗口&#xff0c;設置用戶名和 email 地址。 gi…

生產環境中如何使用Caffeine+Redis實現二級緩存(詳細分析了遇到的各種情況)

生產環境中如何使用CaffeineRedis實現二級緩存&#xff08;詳細分析了各種情況&#xff09; 本篇主要講解的是實現CaffeineRedis實現一個現成的使用流程。下一篇講解什么是Caffeine以及caffeine的使用 00背景&#xff1a; 使用Caffeine和Redis的二級緩存方案源自于分布式系統…

RT-Thread開發文檔合集

瑞薩VisionBoard開發實踐指南 RT-Thread 文檔中心 RT-Thread-【RA8D1-Vision Board】 RA8D1 Vision Board上的USB實踐RT-Thread問答社區 - RT-Thread 【開發板】環境篇&#xff1a;05燒錄工具介紹_嗶哩嗶哩_bilibili 【RA8D1-Vision Board】基于OpenMV 實現圖像分類_嗶哩嗶哩_…

甘果桌面tv版下載-甘果桌面安卓電視版使用教程

甘果桌面 TV 版是一款備受關注的應用&#xff0c;它可以讓安卓電視的界面更加個性化、操作更加便捷。接下來&#xff0c;我們就詳細了解一下甘果桌面 TV 版的下載方法以及安卓電視版的使用教程。 甘果桌面 TV 版下載 打開你的安卓電視&#xff0c;找到并進入電視自帶的應用商店…

RAII資源管理理解

基礎介紹 RAII (Resource Acquisition Is Initialization) 是一種 C 編程范式&#xff0c;這不是一個語法特性&#xff0c;而是一種處理方式。RAII的思想&#xff1a; 資源獲取與對象初始化同時發生資源釋放與對象銷毀同時發生通過對象的生命周期來管理資源&#xff0c;確保資…

解鎖元生代:ComfyUI工作流與云原生后端的深度融合

目錄 藍耘元生代&#xff1a;智算新勢力崛起? ComfyUI 工作流創建詳解? ComfyUI 初印象? 藍耘平臺上搭建 ComfyUI 工作流? 構建基礎工作流實操? 代碼示例與原理剖析? 云原生后端技術全景 云原生后端概念解析? 核心技術深度解讀? 藍耘元生代中兩者的緊密聯系?…