3.11記錄

leetcode刷題:

1.?334. 遞增的三元子序列 - 力扣(LeetCode)

方法一:使用貪心算法求解
class Solution(object):def increasingTriplet(self, nums):first = nums[0]second = float('inf')for i in nums:if i>second:return Trueelif i>first:second=ielif i<first:first=ireturn False

這種方法通過不斷地貪心來解決問題。首先解決的是最大值,如果達到a<b<c那么就直接true,其次是次大,如果比最大值小比最小值大,那么就是次大,最后如果比最小值還小,說明成就遞增三元子序列的可能更大一點。

#方法二:用數組來維護
class Solution(object):def increasingTriplet(self, nums):n=len(nums)left,right=[float("inf")]*n,[float("-inf")]*n# 維護兩個數組,left表示不包括此時左側的最小值,right表示不包括此時的右側的最大值for i in range(1,n):left[i]=min(left[i-1],nums[i-1])for i in range(n-2,0,-1):right[i]=max(right[i+1],nums[i+1])for i in range(1, n - 1):if left[i] < nums[i] < right[i]:return Truereturn False

這種方法維護了兩個數組,分別是left和right,其中left表示當前數字左邊的比當前數字小的,right表示當前數字右邊的比當前數字大的,然后再比較left<nums<right,如果滿足這個條件,說明存在遞增子序列,如果不滿足,則證明不存在,返回False

2.1657. 確定兩個字符串是否接近 - 力扣(LeetCode)

class Solution:def closeStrings(self, word1: str, word2: str) -> bool:dict1=Counter(word1)dict2=Counter(word2)return dict1.keys()==dict2.keys() and sorted(dict1.values())==sorted(dict2.values())

首先比較字符出現是否一樣,然后比較字符出現的次數是否一樣。

plus:當不能替換的時候,就直接

class Solution:def closeStrings(self, word1: str, word2: str) -> bool:dict1=Counter(word1)dict2=Counter(word2)return dict1==dict2

3.437. 路徑總和 III - 力扣(LeetCode)

class Solution:def pathSum(self, root: Optional[TreeNode], targetSum: int) -> int:if root is None:return 0def dfs(root,target):count=0if root.val==target:count+=1if root.left:count+=dfs(root.left,target-root.val)if root.right:count+=dfs(root.right,target-root.val)return countreturn dfs(root,targetSum)+self.pathSum(root.left,targetSum)+self.pathSum(root.right,targetSum)

這道題難點在于是否考慮本節點被選擇,以及dfs的運用。

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

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

相關文章

阿里云操作系統控制臺評測:國產AI+運維 一站式運維管理平臺

阿里云操作系統控制臺評測&#xff1a;國產AI運維 一站式運維管理平臺 引言 隨著云計算技術的飛速發展&#xff0c;企業在云端的運維管理面臨更高的要求。阿里云操作系統控制臺作為一款集運維管理、智能助手和系統診斷等多功能于一體的工具&#xff0c;正逐步成為企業高效管理…

大語言模型學習--向量數據庫Milvus實踐

Milvus是目前比較流行的開源向量數據庫&#xff0c;其官網地址 Milvus 是什么&#xff1f; | Milvus 文檔 1.Milvus簡介 Milvus 是一種高性能、高擴展性的向量數據庫。Milvus 提供強大的數據建模功能&#xff0c;能夠將非結構化或多模式數據組織成結構化的 Collections。它支…

DeepSeek Kimi詳細生成PPT的步驟

以下是使用 DeepSeek 和 Kimi 協作生成 PPT 的詳細步驟&#xff0c;結合了兩者的優勢實現高效創作&#xff1a; 第一步&#xff1a;使用 DeepSeek 生成 PPT 大綱或內容 明確需求并輸入提示詞 在 DeepSeek 的對話界面中&#xff0c;輸入具體指令&#xff0c;要求生成 PPT 大綱或…

Visual Studio 安裝及使用教程(Windows)【安裝】

文章目錄 一、 Visual Studio 下載1. 官網下載2. 其它渠道 二、Visual Studio 安裝三、Visual Studio 使用四、Visual Studio 其它設置1. 桌面快捷方式2. 更改主題、字體大小 軟件 / 環境安裝及配置目錄 一、 Visual Studio 下載 1. 官網下載 安裝地址&#xff1a;https://vi…

Java多線程與高并發專題——阻塞和非阻塞隊列的并發安全原理是什么?

引入 之前我們探究了常見的阻塞隊列的特點&#xff0c;在本文我們就以 ArrayBlockingQueue 為例&#xff0c;首先分析 BlockingQueue &#xff0c;也就是阻塞隊列的線程安全原理&#xff0c;然后再看看它的兄弟——非阻塞隊列的并發安全原理。 ArrayBlockingQueue 源碼分析 …

關于ngx-datatable no data empty message自定義模板解決方案

背景&#xff1a;由于ngx-dataable插件默認沒有數據時顯示的文案是no data to display&#xff0c;且沒有任何樣式。這里希望通過自定義模板來實現。但目前github中有一個案例是通過設置代碼&#xff1a; https://swimlane.github.io/ngx-datatable/empty** <ngx-datatable…

Matlab 雙線性插值(二維)

文章目錄 一、簡介二、實現代碼三、實現效果參考資料一、簡介 雙線性插值是一種 二維插值方法,用于計算 柵格(Grid) 或 像素點 之間的插值值。它主要用于 圖像縮放、旋轉、變換 等操作,以在新像素位置估算灰度值或顏色值。 如上圖所示,假設存在一個二維離散函數(如圖像)…

coding ability 展開第二幕(雙指針——鞏固篇)超詳細!!!!

文章目錄 前言有效的三角形個數思路 查找總價格為目標值的兩個商品思路 兩數之和思路 三數之和思路 四數之和思路 總結 前言 本專欄的上篇&#xff0c;講述了雙指針的一些基礎的算法習題 今天我們來學習更進一步的雙指針用法吧 其實也是大相徑庭&#xff0c;和前面的差不多&…

L1-056 猜數字

L1-056 猜數字 - 團體程序設計天梯賽-練習集 (pintia.cn) 題解 這道題要求&#xff1a;一群人坐在一起&#xff0c;每人猜一個 100 以內的數&#xff0c;誰的數字最接近大家平均數的一半就贏。現在需要編寫程序來計算&#xff0c;其中需要存入玩家的名字&#xff08;字符串&a…

處理Java中的異常

處理Java中的異常 在 Java 中&#xff0c;異常處理是通過 try-catch-finally 語句來實現的。Java 提供了一種強大的機制&#xff0c;用于捕捉和處理程序運行中的各種錯誤和異常。通過這種方式&#xff0c;你可以有效地捕捉到可能導致程序崩潰的錯誤&#xff0c;并做出相應的處…

一維數組的增刪改查:對元素的影響

一維數組的增刪改查:對元素的影響(C語言) 在C語言中,一維數組是一種存儲一組相同類型元素的數據結構。它在內存中是連續存儲的,每個元素都可以通過索引來訪問和修改。在這篇博文中,我們將詳細探討一維數組的增、刪、改、查操作,并分析它們對數組元素的影響。 1. 一維數…

項目實操分享:一個基于 Flask 的音樂生成系統,能夠根據用戶指定的參數自動生成 MIDI 音樂并轉換為音頻文件

在線體驗音樂創作&#xff1a;AI Music Creator - AI Music Creator 體驗者賬號密碼admin/admin123 系統架構 1.1 核心組件 MusicGenerator 類 負責音樂生成的核心邏輯 包含 MIDI 生成和音頻轉換功能 管理音樂參數和音軌生成 FluidSynth 集成 用于 MIDI 到音頻的轉換 …

關于MCP SSE 服務器的工作原理

模型上下文協議&#xff08;Model Context Protocol&#xff0c;簡稱MCP&#xff09; 是一種全新的開放協議&#xff0c;專門用于標準化地為大語言模型&#xff08;LLMs&#xff09;提供應用場景和數據背景。 你可以把MCP想象成AI領域的“USB-C接口”&#xff0c;它能讓不同的A…

計算機:基于深度學習的Web應用安全漏洞檢測與掃描

目錄 前言 課題背景和意義 實現技術思路 一、算法理論基礎 1.1 網絡爬蟲 1.2 漏洞檢測 二、 數據集 三、實驗及結果分析 3.1 實驗環境搭建 3.2 模型訓練 最后 前言 &#x1f4c5;大四是整個大學期間最忙碌的時光,一邊要忙著備考或實習為畢業后面臨的就業升學做準備,…

win32匯編環境,網絡編程入門之二

;運行效果 ;win32匯編環境,網絡編程入門之二 ;本教程在前一教程的基礎上,研究一下如何得到服務器的返回的信息 ;正常的邏輯是連接上了,然后我發送什么,它返回什么,但是這有一個很尷尬的問題。 ;就是如何表現出來。因為網絡可能有延遲,這個延遲并不確定有多久。 ;而程序是順…

【高分論文密碼】AI大模型和R語言的全類型科研圖形繪制,從畫圖、標注、改圖、美化、組合、排序分解科研繪圖每個步驟

在科研成果競爭日益激烈的當下&#xff0c;「一圖勝千言」已成為高水平SCI期刊的硬性門檻——數據顯示很多情況的拒稿與圖表質量直接相關。科研人員普遍面臨的工具效率低、設計規范缺失、多維數據呈現難等痛點&#xff0c;因此科研繪圖已成為成果撰寫中的至關重要的一個環節&am…

大語言模型-1.2-大模型技術基礎

簡介 本博客內容是《大語言模型》一書的讀書筆記&#xff0c;該書是中國人民大學高瓴人工智能學院趙鑫教授團隊出品&#xff0c;覆蓋大語言模型訓練與使用的全流程&#xff0c;從預訓練到微調與對齊&#xff0c;從使用技術到評測應用&#xff0c;幫助學員全面掌握大語言模型的…

uni-app打包成H5使用相對路徑

網上找了一圈&#xff0c;沒用&#xff0c;各種試&#xff0c;終于給試出來了&#xff0c;主要是網絡上的沒有第二步&#xff0c;只有第一步&#xff0c;導致打包之后請求的路徑沒有帶上域名 運行的基礎路徑設置為./ config.js文件里面的baseUrl路徑改成空字符&#xff0c;千萬…

Android UI性能優化

Android UI性能優化 一、UI性能優化基礎 1.1 UI渲染原理 Android系統的UI渲染是通過一個被稱為"UI線程"或"主線程"的單線程模型來完成的。系統會以16ms(約60fps)的固定時間間隔發送VSYNC信號,觸發UI的渲染流程。如果一幀的處理時間超過16ms,就會出現丟…

【16】單片機編程核心技巧:移位運算的應用

【16】單片機編程核心技巧&#xff1a;移位運算的應用 七律 移位 左遷乘二寄存移&#xff0c;右徙除二暫寄時。 二進玄機藏位里&#xff0c;一移妙法化玄機。 合璧分疆拼字節&#xff0c;置位清零控毫厘。 速效堪超乘除算&#xff0c;單片機中展神威。 摘要 移位運算是單片…