LeetCode 每日一題 2024/2/26-2024/3/3

記錄了初步解題思路 以及本地實現代碼;并不一定為最優 也希望大家能一起探討 一起進步


目錄

      • 2/26 938. 二叉搜索樹的范圍和
      • 2/27 2867. 統計樹中的合法路徑數目
      • 2/28 2673. 使二叉樹所有路徑值相等的最小代價
      • 2/29 2581. 統計可能的樹根數目
      • 3/1 2369. 檢查數組是否存在有效劃分
      • 3/2 2368. 受限條件下可到達節點的數目
      • 3/3


2/26 938. 二叉搜索樹的范圍和

dfs 判斷節點值是否在區間內

class TreeNode(object):def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = right
def rangeSumBST(root, low, high):""":type root: TreeNode:type low: int:type high: int:rtype: int"""def dfs(node):ret = 0if node.val>low:if node.left:ret = dfs(node.left)if node.val>=low and node.val<=high:ret+=node.valif node.val<high:if node.right:ret += dfs(node.right)return retreturn dfs(root)

2/27 2867. 統計樹中的合法路徑數目

歐拉篩篩選質數
以質數節點為根 深搜所有非質數的子樹
求字數大小 任意兩個不同子樹節點 路徑都通過質數根節點
只有一個節點為質數 符合題意

def countPaths(n, edges):""":type n: int:type edges: List[List[int]]:rtype: int"""prime=[]isprime = [True]*(n+1)isprime[1]=Falsefor i in range(2,n+1):if isprime[i]:prime.append(i)for p in prime:if p*i>n:breakisprime[p*i]=Falseif i%p==0:breakm=[[] for _ in range(n+1)]for i,j in edges:m[i].append(j)m[j].append(i)global seendef dfs(i,pre):global seenseen.append(i)for j in m[i]:if j!=pre and not isprime[j]:dfs(j,i)ans = 0cnt=[0]*(n+1)for i in range(1,n+1):if not isprime[i]:continuecur = 0for j in m[i]:if isprime[j]:continueif cnt[j]==0:seen = []dfs(j,0)for k in seen:cnt[k] = len(seen)ans+=cnt[j]*curcur+=cnt[j]ans+=curreturn ans

2/28 2673. 使二叉樹所有路徑值相等的最小代價

滿二叉樹有n個節點 那么存在(n+1)//2個葉子節點
對于兩個兄弟葉子節點 除了改變其自身 無法改變兩個節點路徑和的差值
所以將小的葉子節點增加到大的即可
改完葉子節點 將葉子節點的值增加到父節點中 依舊考慮父節點和叔節點的情況

def minIncrements(n, cost):""":type n: int:type cost: List[int]:rtype: int"""ans=0for i in range(n-2,0,-2):ans += abs(cost[i]-cost[i+1])cost[i//2] += max(cost[i],cost[i+1])return ans

2/29 2581. 統計可能的樹根數目

首先計算以0位根節點時猜對的個數cnt
當根節點從0換到其某個子節點x時
除了0,x的父子關系發生變化 其他沒有變化
所以如果此時(0,x)在猜測中 則cnt-1
如果(x,0)在猜測中 則cnt+1
遇到cnt>=k 則ans+1

def rootCount(edges, guesses, k):""":type edges: List[List[int]]:type guesses: List[List[int]]:type k: int:rtype: int"""g=[[] for _ in range(len(edges)+1)]for x,y in edges:g[x].append(y)g[y].append(x)s = {(x,y) for x,y in guesses}global cnt,ansans = 0cnt = 0def dfs(x,p):global cntfor y in g[x]:if y!=p:cnt += (x,y) in sdfs(y,x)dfs(0,-1)def reroot(x,p,cnt):global ansif cnt>=k:ans+=1for y in g[x]:if y!=p:reroot(y,x,cnt-((x,y) in s) +((y,x) in s))reroot(0,-1,cnt)return ans

3/1 2369. 檢查數組是否存在有效劃分

dp[i+1]判斷是否能夠有效劃分0~i

def validPartition(nums):""":type nums: List[int]:rtype: bool"""n=len(nums)dp=[False]*(n+1)dp[0]=Truefor i,x in enumerate(nums):if (i>0 and dp[i-1] and x==nums[i-1]) or (i>1 and dp[i-2] and (x==nums[i-1]==nums[i-2] or x==nums[i-1]+1==nums[i-2]+2)):dp[i+1]=Truereturn dp[n]

3/2 2368. 受限條件下可到達節點的數目

不考慮受限的節點 建圖
DFS搜索

def reachableNodes(n, edges, restricted):""":type n: int:type edges: List[List[int]]:type restricted: List[int]:rtype: int"""s = set(restricted)m = [[] for _ in range(n)]for x,y in edges:if x not in s and y not in s:m[x].append(y)m[y].append(x)def dfs(x,f):cnt = 1for y in m[x]:if y!=f:cnt += dfs(y,x)return cntreturn dfs(0,-1)

3/3


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

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

相關文章

leetcode 熱題 100_三數之和

題解一&#xff1a; 雙指針遍歷&#xff1a;暴力解法的三層遍歷會超時&#xff0c;因此需要優化遍歷的過程。首先是需要對結果進行去重&#xff0c;這里采用排序跳過重復值的做法&#xff0c;在指針遍歷時跳過已經遍歷過的相同值。在第一層循環確定第一個值后&#xff0c;剩下兩…

模型部署 - onnx 的導出和分析 -(1) - PyTorch 導出 ONNX - 學習記錄

onnx 的導出和分析 一、PyTorch 導出 ONNX 的方法1.1、一個簡單的例子 -- 將線性模型轉成 onnx1.2、導出多個輸出頭的模型1.3、導出含有動態維度的模型 二、pytorch 導出 onnx 不成功的時候如何解決2.1、修改 opset 的版本2.2、替換 pytorch 中的算子組合2.3、在 pytorch 登記&…

vscode+remote突然無法連接服務器以及ssh連接出問題時的排錯方法

文章目錄 設備描述狀況描述解決方法當ssh連接出問題時的排錯方法 設備描述 主機&#xff1a;win11&#xff0c;使用vscode的remote-ssh插件 服務器&#xff1a;阿里云的2C2GUbuntu 22.04 UFIE 狀況描述 之前一直使用的是vscode的remote服務&#xff0c;都是能夠正常連接服務…

【Qt】界面布局

Qt常用布局 除Qt Designer支持可視化設計和布局界面之外&#xff0c;Qt 提供了代碼方式來進行界面布局&#xff0c; 以下是幾種常用的界面布局方式&#xff1a; 水平布局&#xff08;QHBoxLayout&#xff09;和垂直布局&#xff08;QVBoxLayout&#xff09;&#xff1a; QHBo…

Redis常用數據結構--Zset

Zset ZADDZCARDZCOUNTZRANGE/ZREVRANGEZRANGEBYSCOREZPOPMAX/ZPOPMINBZPOPMAX/BZPOPMINZRANK/ZREVRANKZSCOREZREMZREMRANGEBYRANKZREMRANGEBYSCOREZINCRBYZINTERSTORE/ZUNIONSTORE內部編碼使?場景 ZADD 添加或者更新指定的元素以及關聯的分數到 zset 中&#xff0c;分數應該符…

如何在 Angular 測試中使用 spy

簡介 Jasmine spy 用于跟蹤或存根函數或方法。spy 是一種檢查函數是否被調用或提供自定義返回值的方法。我們可以使用spy 來測試依賴于服務的組件&#xff0c;并避免實際調用服務的方法來獲取值。這有助于保持我們的單元測試專注于測試組件本身的內部而不是其依賴關系。 在本…

空調壓縮機補充潤滑油的方法

空調壓縮機補充潤滑油的方法有三種&#xff0c;從吸氣截止閥旁邊通孔吸入&#xff0c;從加油孔中加入&#xff0c;從曲軸箱下部加入&#xff0c;具體操作步驟如下&#xff1a; 1關閉吸氣截止閥&#xff0c;啟動壓縮機幾分鐘&#xff0c;將曲軸箱中制冷劑排入冷凝器&#xff0c…

vue2結合electron開發桌面端應用

一、Electron是什么&#xff1f; Electron是一個使用 JavaScript、HTML 和 CSS 構建桌面應用程序的框架。 嵌入 Chromium 和 Node.js 到 二進制的 Electron 。允許您保持一個 JavaScript 代碼代碼庫并創建可在Windows、macOS和Linux上運行的跨平臺應用 。 Electron 經常與 Ch…

scrapy 中間件

就是發送請求的時候&#xff0c;會經過&#xff0c;中間件。中間件會處理&#xff0c;你的請求 下面是代碼&#xff1a; # Define here the models for your spider middleware # # See documentation in: # https://docs.scrapy.org/en/latest/topics/spider-middleware.html…

【快速上手ProtoBuf】基本使用

文章目錄 1 :peach:初識 ProtoBuf:peach:1.1 :apple:序列化概念:apple:1.2 :apple:ProtoBuf 是什么:apple:1.3 :apple:ProtoBuf 的使用特點:apple: 2 :peach:創建 .proto ?件:peach:3 :peach:編譯 .proto 文件:peach:3 :peach:序列化與反序列化的使用:peach: 1 &#x1f351;初…

洛谷 2036.PERKET

采用遞歸法的方式進行題解。 思路&#xff1a;首先我們知道在n種材料當中&#xff0c;我們需要從中選擇至少有一種得配料才行。也就是說&#xff0c;我們選擇的配料數目是自己決定的&#xff0c;而不是那種組合型得對于你有要求的組合型遞歸方式。 所以我們會想到用指數型得遞…

(五)網絡優化與超參數選擇--九五小龐

網絡容量 網絡中神經單元數越多&#xff0c;層數越多&#xff0c;神經網路的擬合能力越強。但是訓練速度&#xff0c;難度越大&#xff0c;越容易產生過擬合。 如何選擇超參數 所謂超參數&#xff0c;也就是搭建神經網路中&#xff0c;需要我們自己去選擇&#xff08;不是通…

LeetCode 刷題 [C++] 第45題.跳躍游戲 II

題目描述 給定一個長度為 n 的 0 索引整數數組 nums。初始位置為 nums[0]。 每個元素 nums[i] 表示從索引 i 向前跳轉的最大長度。換句話說&#xff0c;如果你在 nums[i] 處&#xff0c;你可以跳轉到任意 nums[i j] 處: 0 < j < nums[i]i j < n 返回到達 nums[n …

遞歸函數(c++題解)

題目描述 對于一個遞歸函數w(a, b, c)。 如果a < 0 or b < 0 or c < 0就返回值1。 如果a > 20 or b > 20 or c > 20就返回W(20,20,20)。 如果a < b并且b < c 就返回w(a, b, c ? 1) w(a, b ? 1, c ? 1) ? w(a, b ? 1, c)&#xff0c; 其它別…

計算機網絡知多少-第1篇

一、 從輸入URL到頁面展示到底發生了什么&#xff1f; 1. 首先瀏覽器會查看電腦本地緩存&#xff0c;如果有直接返回&#xff0c;否則需要進行下一步的網絡請求。 2. 在網絡請求之前&#xff0c;需要先進行DNS解析&#xff0c;來找到請求域名的ip地址。如果是HTTPS請求&#…

【C語言】熟悉文件基礎知識

歡迎關注個人主頁&#xff1a;逸狼 創造不易&#xff0c;可以點點贊嗎~ 如有錯誤&#xff0c;歡迎指出~ 文件 為了數據持久化保存&#xff0c;使用文件&#xff0c;否則數據存儲在內存中&#xff0c;程序退出&#xff0c;內存回收&#xff0c;數據就會丟失。 程序設計中&…

微信小程序,h5端自適應登陸方式

微信小程序端只顯示登陸(獲取opid),h5端顯示通過賬戶密碼登陸 例如: 通過下面的變量控制: const isWeixin ref(false); // #ifdef MP-WEIXIN isWeixin.value true; // #endif

Git 查看提交歷史

命令說明git log查看歷史提交記錄git blame (file)以列表形式查看指定文件的歷史修改記錄 git log 在使用 Git 提交了若干更新之后&#xff0c;又或者克隆了某個項目&#xff0c;想回顧下提交歷史&#xff0c;我們可以使用 git log 命令查看。 git log 命令用于查看 Git 倉庫中…

LIN基礎:從LIN Frame開始

目錄&#xff1a; 1、LIN的網絡拓撲 2、LIN Frame 1&#xff09;Header 2&#xff09;Response 3、LIN的通信規則 1&#xff09;LIN的發送行為示例 2&#xff09;LIN的接收行為示例 雖然LIN總線的通信速率不高&#xff0c;工程中&#xff0c;最高的速率也就19200bps。…

c語言extern關鍵字

extern 是C和C中的關鍵字&#xff0c;用于聲明一個變量或函數的存在&#xff0c;但不進行定義。 它通常用于在一個源文件中引用另一個源文件中定義的變量或函數。 例如&#xff0c;extern int x; 表示 x 是一個整數變量&#xff0c;但它的實際定義將在其他文件中。在引用它的文…