python leetcode簡單練習(2)

20 有效括號


方法思路

要判斷一個僅由括號組成的字符串是否有效,可以使用棧這一數據結構。核心思路是遍歷字符串中的每個字符,遇到左括號時壓入棧中,遇到右括號時檢查棧頂的左括號是否匹配。若匹配則彈出棧頂元素,否則返回false。最終,若棧為空則說明所有括號正確閉合。

class Solution:def isValid(self,s):class Solution:def isValid(self,s):dic = {')':'(',']':'[','}':'{'}stack = []for i in s:if i in dic:if not stack or dic[i] != stack[-1]:return Falsestack.pop()else:stack.append(i)return not stack

?21. 合并兩個有序鏈表

方法思路

合并兩個有序鏈表可以通過逐個比較節點值并逐步構建新鏈表來實現。使用虛擬頭節點簡化初始條件處理,然后用指針依次連接較小值的節點,直到其中一個鏈表遍歷完畢,最后將剩余鏈表直接接上。

class ListNode:def __init__(self,val=0,next=None):self.val = valself.next = next
class Solution:def mergeTwoLists(self,list1,list2):LNode = ListNode()p = LNode #虛擬指針while list1 and list2:if list1.val <= list2.val:p.next = list1list1 = list1.nextelse:p.next = list2list2 = list2.nextp = p.nextp.next = list1 if list1 else list2return LNode.next

26. 刪除有序數組中的重復項

但實際上題目只要求前k個元素正確,后面的元素無關緊要。

方法思路

使用雙指針法,快指針遍歷數組,慢指針記錄當前有效位置。由于數組已排序,重復元素必然相鄰,遇到不同元素時將其移至慢指針位置,最后返回慢指針位置+1即為新數組長度。

#k是慢指針,用來記錄我們想要的數組真正的下標,i是快指針用來遍歷數組
class Solution:def removeDuplicates(self,nums):if not nums:return 0k = 0for i in range(1,len(nums)):if nums[i] != nums[k]:k += 1nums[k] = nums[i]return k+1

27.移除元素

但實際上題目只要求前k個元素正確,后面的元素無關緊要。

使用雙指針法,快指針遍歷數組,慢指針記錄有效位置。將非目標值的元素移至數組前部,最后返回有效長度。

class Solution:def removeElement(self,nums,val):if not nums:return 0k = 0for i in range(0,len(nums)):if nums[i] != val:nums[k] = nums[i]k += 1return k

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

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

相關文章

AI 數字人短視頻數字人口播源碼:短視頻內容生產的新引擎?

在當下信息爆炸的時代&#xff0c;短視頻已成為主流的信息傳播與娛樂方式之一。在如此龐大的市場需求下&#xff0c;如何高效、創新地生產短視頻內容成為了行業關注的焦點。AI 數字人短視頻數字人口播源碼應運而生&#xff0c;為短視頻內容生產帶來了全新的變革。? 一、行業背…

AI對傳統IT行業的變革

傳統 IT 行業長期以來面臨著諸多挑戰。系統類型繁雜、復雜度高&#xff0c;不少環節依賴人工操作&#xff0c;智能化水平偏低&#xff0c;極大地制約了業務運營效率。此外&#xff0c;傳統 IT 企業背負沉重的歷史包袱&#xff0c;重構系統不僅成本高昂&#xff0c;由于現有系統…

mapbox基礎,使用geojson加載cluster聚合圖層

????? 主頁: gis分享者 ????? 感謝各位大佬 點贊?? 收藏? 留言?? 加關注?! ????? 收錄于專欄:mapbox 從入門到精通 文章目錄 一、??前言1.1 ??mapboxgl.Map 地圖對象1.2 ??mapboxgl.Map style屬性1.3 ??circle點圖層樣式二、??使用geojson加…

Git回退文件到指定提交

你可以使用 git checkout 命令將某個文件回退到指定提交的版本。以下是具體步驟&#xff1a; 1. 找到目標提交的哈希值 git log --oneline通過 git log 查看提交歷史&#xff0c;找到你要回退到的目標提交的哈希值&#xff08;例如 abc123d&#xff09;。 2. 回退文件到指定提…

如何屏蔽mac電腦更新提醒,禁止系統更新

最煩mac的系統更新提醒了&#xff0c;過幾天就是更新彈窗提醒&#xff0c;現在可以直接禁掉了&#xff0c;眼不見心不亂&#xff0c;不然一升級&#xff0c;開發環境全都不能用了&#xff0c;那才是最可怕的&#xff0c;屏蔽的方法也很簡單&#xff0c;就是屏蔽mac系統更新的請…

mac m1/m2/m3 pyaudio的安裝

google了很多方法&#xff0c;也嘗試了 issue68的方法&#xff0c; 但是均失敗了&#xff0c;但是問deepseek竟然成功了&#xff0c;下面是deepseek r1給出的方法。在M3 pro芯片上可以成功運行. 安裝homebrew /bin/bash -c "$(curl -fsSL https://raw.githubusercontent…

hackmyvm-JO2024

arp-scan -l nmap -sS -v 192.168.222.202 gobuster dir -u http://192.168.222.202 -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt -x php -b 301,401,403,404 訪問/preferences.php 看一下cookie 解密 TzoxNToiVXNlclByZWZlcmVuY2VzIjoyOntzOjg6Imxhbmd1…

從零開始學習SQL

1.1 MySQL概述 1. 數據管理技術的發展過程 數據庫技術是應數據管理任務的需要而產生的 a. 什么是數據管理 ** 對數據進行收集、分類、組織、編碼、存儲、檢索和維護一系列活動的總和 **b. 數據管理技術的發展過程 人工管理階段&#xff08;20世紀50年代中之前&#xff09;…

輸電線路在線監測通信規約,即I1協議

文章目錄 概要整體架構流程數據幀格式技術細節 概要 輸電線路在線監測系統 transmission lines online monitoring system 監測輸電線路設備本體、氣象環境、通道狀況等信息&#xff0c;定性或定量分析輸電線路運行狀況的應用系 統。一般包括主站系統、監測裝置以及主站系統與…

【AI】Orin NX+ubuntu22.04上移植YoloV11,并使用DeepStream測試成功

【AI】郭老二博文之:AI學習目錄匯總 1、燒寫系統 新到的開發板,已經燒寫好Ubuntu系統,版本為22.04。 如果沒有升級到Ubuntu22.04,可以在電腦Ubuntu系統中使用SDKManager來燒寫Ubuntu系統,網絡情況好的話,也可以直接將CUDA、cuDNN、TensorRT、Deepstream等也安裝上。 2…

C++之輸入與輸出

文章目錄 C 輸入輸出 (I/O) 詳解基本 I/O 組件&#xff08;input / output&#xff09;基本輸出 (cout)基本輸入 (cin)格式化輸出文件 I/O字符串流常見 I/O 方法比較錯誤處理其他保留小數 C 輸入輸出 (I/O) 詳解 C 使用標準庫中的 iostream 庫來處理輸入輸出操作。主要包括以下…

流動的夢境:GPT-4o 的自回歸圖像生成深度解析

每周跟蹤AI熱點新聞動向和震撼發展 想要探索生成式人工智能的前沿進展嗎&#xff1f;訂閱我們的簡報&#xff0c;深入解析最新的技術突破、實際應用案例和未來的趨勢。與全球數同行一同&#xff0c;從行業內部的深度分析和實用指南中受益。不要錯過這個機會&#xff0c;成為AI領…

eBay多賬號安全運營技術體系:從環境隔離到智能風控的工程化實踐

一、多賬號運營風險模型解析 &#xff08;技術化重構關聯檢測機制&#xff09; 環境指紋維度&#xff1a; 瀏覽器指紋參數&#xff1a;Canvas/WebGL渲染特征&#xff08;差異度要求≥98%&#xff09; 設備指紋參數&#xff1a;GPU型號/聲卡特征&#xff08;識別準確率92%&…

Vue 3 模板引用(Template Refs)詳解與實戰示例

Vue 3 模板引用&#xff08;Template Refs&#xff09;詳解與實戰示例 引言 在 Vue 開發中&#xff0c;通常推薦使用 響應式數據 (ref 和 reactive) 進行數據綁定&#xff0c;而不是直接操作 DOM。但是&#xff0c;在某些情況下&#xff0c;我們確實需要訪問某個組件或 DOM 元…

《Operating System Concepts》閱讀筆記:p495-p511

《Operating System Concepts》學習第 44 天&#xff0c;p495-p511 總結&#xff0c;總計 17 頁。 一、技術總結 1.cache (1)定義 A cache is a region of fast memory that holds copies of data. (2)cache 和 buffer 的區別 The difference between a buffer and a cac…

通過Spring Boot集成WebSocket進行消息通信

文章目錄 通過Spring Boot集成WebSocket進行消息通信1. 創建 Spring Boot 項目2. 添加 WebSocket 依賴3. 配置 WebSocket4. 創建 WebSocket 處理器5. 創建控制器&#xff08;可選&#xff09;6. 前端頁面測試7. 運行項目注意事項 通過Spring Boot集成WebSocket進行消息通信 1.…

rust服務應用開發框架

原文鏈接:https://i68.ltd/notes/posts/20250313-rust-wasm-fw/ spin 開源開發工具&#xff0c;用于構建和運行由 WebAssembly 提供支持的無服務器應用程序Spin 是一個框架&#xff0c;用于使用 WebAssembly 構建&#xff0c;部署和運行快速&#xff0c;安全和可組合的云端微…

迷茫的一周 2025/3/28

Java篇 在Java中&#xff0c;以下數據類型中,需要內存最多的是(long) - A選項byte&#xff1a;占用1個字節&#xff08;8位&#xff09; - B選項long&#xff1a;占用8個字節&#xff08;64位&#xff09; - C選項Object&#xff1a;Object本身是一個引用&#xff0c;在32位JVM…

Elasticsearch 的搜索功能

Elasticsearch 的搜索功能 建議閱讀順序&#xff1a; Elasticsearch 入門Elasticsearch 搜索&#xff08;本文&#xff09;Elasticsearch 搜索高級Elasticsearch 高級 1. 介紹 使用 Elasticsearch 最終目的是為了實現搜索功能&#xff0c;現在先將文檔添加到索引中&#xff0c…

docker鏡像拉取失敗

hub.docker.com中提供的docker pull命令在服務器拉取鏡像時報錯Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers) 這個錯誤通常表明Docker客戶…