每日一題 2867統計樹中的合法路徑

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

題目描述:

給你一棵?n?個節點的無向樹,節點編號為?1?到?n?。給你一個整數?n?和一個長度為?n - 1?的二維整數數組?edges?,其中?edges[i] = [ui, vi]?表示節點?ui?和?vi?在樹中有一條邊。

請你返回樹中的?合法路徑數目?。

如果在節點?a?到節點?b?之間?恰好有一個?節點的編號是質數,那么我們稱路徑?(a, b)?是?合法的?。

注意:

  • 路徑?(a, b)?指的是一條從節點?a?開始到節點?b?結束的一個節點序列,序列中的節點?互不相同?,且相鄰節點之間在樹上有一條邊。
  • 路徑?(a, b)?和路徑?(b, a)?視為?同一條?路徑,且只計入答案?一次?。

示例 1:

輸入:n = 5, edges = [[1,2],[1,3],[2,4],[2,5]]
輸出:4
解釋:恰好有一個質數編號的節點路徑有:
- (1, 2) 因為路徑 1 到 2 只包含一個質數 2 。
- (1, 3) 因為路徑 1 到 3 只包含一個質數 3 。
- (1, 4) 因為路徑 1 到 4 只包含一個質數 2 。
- (2, 4) 因為路徑 2 到 4 只包含一個質數 2 。
只有 4 條合法路徑。

示例 2:

輸入:n = 6, edges = [[1,2],[1,3],[2,4],[3,5],[3,6]]
輸出:6
解釋:恰好有一個質數編號的節點路徑有:
- (1, 2) 因為路徑 1 到 2 只包含一個質數 2 。
- (1, 3) 因為路徑 1 到 3 只包含一個質數 3 。
- (1, 4) 因為路徑 1 到 4 只包含一個質數 2 。
- (1, 6) 因為路徑 1 到 6 只包含一個質數 3 。
- (2, 4) 因為路徑 2 到 4 只包含一個質數 2 。
- (3, 6) 因為路徑 3 到 6 只包含一個質數 3 。
只有 6 條合法路徑。

提示:

  • 1 <= n <= 10^5
  • edges.length == n - 1
  • edges[i].length == 2
  • 1 <= ui, vi <= n
  • 輸入保證?edges?形成一棵合法的樹。

思路:

1)雖然他是想構成一棵樹,但個人覺得更像縮減版的圖,不過最后一句提示“輸入保證?edges?形成一棵合法的樹。”保證了樹的存在。但其實質相同,就是對圖的每一個節點,深度遍歷,然后統計“合法”的路徑數量

2)枚舉每個質數節點,從質數的鄰居開始dfs,統計在不經過質數的前提下能訪問到多少個非質數。以下圖為例,假設2的鄰居能訪問到3,4,5個非質數。

4和左邊這3個點,兩兩之間的路徑都只包含質數2。5和左邊這3+4個點,兩兩之間的路徑都只包含質數2.根據乘法原理,把4*3+5*7加到答案中。注:只考慮左邊是避免重復統計。最后,從2出發到下面這3+4+5=12個點的路徑也只包含質數2把12加到答案中。

代碼:

#標記10^5以內質數
MX=10**5+1
isPrime=[True]*MX
isPrime[1]=False
for i in range(2,isqrt(MX)+1):if isPrime[i]:for j in range(i*i,MX,i):#j為i的倍數,代表非質數isPrime[j]=Falseclass Solution:def countPaths(self, n: int, edges: List[List[int]]) -> int:#構建鄰接表g=[[] for _ in range(n+1)]for x,y in edges:g[x].append(y)g[y].append(x)def dfs(x:int,fa:int)->None:nodes.append(x)for y in g[x]:if y !=fa and not isPrime[y]:dfs(y,x)ans = 0size = [0] * (n + 1)for x in range(1, n + 1):if not isPrime[x]:  # 跳過非質數continues=0for y in g[x]:  # 質數 x 把這棵樹分成了若干個連通塊if isPrime[y]:continueif size[y]==0:#還沒計算的nodes=[]dfs(y,-1) # 遍歷 y 所在連通塊,在不經過質數的前提下,統計有多少個非質數for z in nodes:size[z]=len(nodes)# 這 size[y] 個非質數與之前遍歷到的 s 個非質數,兩兩之間的路徑只包含質數 xans+=size[y]*ss+=size[y]ans+=s  #從x出發的路徑return ans

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

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

相關文章

Nginx 反向代理入門教程

Nginx 反向代理入門教程 一、什么是反向代理 反向代理&#xff08;Reverse Proxy&#xff09;方式是指以代理服務器來接受Internet上的連接請求&#xff0c;然后將請求轉發給內部網絡上的服務器&#xff1b;并將從服務器上得到的結果返回給Internet上請求連接的客戶端&#x…

Vue 2.0 與 Vue 3.0 的主要差異

Vue 2.0 與 Vue 3.0 的主要差異 在前端框架的世界中&#xff0c;Vue.js 已經成為了一股不可忽視的力量。自從 Vue.js 首次亮相以來&#xff0c;它便以其輕量級、靈活性和易用性贏得了開發者的喜愛。然而&#xff0c;隨著技術的不斷進步和開發者需求的不斷變化&#xff0c;Vue.…

Android AppCompatActivity 方法詳解

在 Android 開發中&#xff0c;AppCompatActivity 是一個常用的類&#xff0c;它提供了對新版 Android 特性在舊版 Android 上的兼容支持。作為 Android 支持庫的一部分&#xff0c;它通常被用作活動&#xff08;Activity&#xff09;的基類。下面我們將介紹 AppCompatActivity…

Vins-Moon配準運行

Vins-Moon運行 源碼地址電腦配置環境配置編譯適配Kitti數據集運行結果Euroc數據集kitti數據集 evo評估&#xff08;KITTI數據&#xff09;輸出軌跡(tum格式)結果 源碼地址 源碼鏈接&#xff1a;https://github.com/HKUST-Aerial-Robotics/VINS-Mono.git 電腦配置 Ubuntu 18.…

破解SQL Server迷局,徹底解決“管道的另一端無任何進程錯誤233”

問題描述&#xff1a;在使用 SQL Server 2014的時候&#xff0c;想用 SQL Server 身份方式登錄 SQL Servcer Manager&#xff0c;結果報錯&#xff1a; 此錯誤消息&#xff1a;表示SQL Server未偵聽共享內存或命名管道協議。 問題原因&#xff1a;此問題的原因有多種可能 管道…

人才測評系統在企業中的作用有哪些?

一個企業除了產出價值給社會&#xff0c;它還有自己的工作架構體系&#xff0c;無論的工作時間制度上&#xff0c;還是工資組成方向&#xff0c;這樣公司才能正常運轉&#xff0c;那么人才測評系統可以在企業中充當一個什么角色呢&#xff1f;又或者說它起著什么作用呢&#xf…

【數據結構】棧和隊列(概念選擇題)

1.概念選擇題 1.一個棧的初始狀態為空。現將元素1、2、3、4、5、A、B、C、D、E依次入棧&#xff0c;然后再依次出棧&#xff0c;則元素出 棧的順序是&#xff08; &#xff09;。 A 12345ABCDE B EDCBA54321 C ABCDE12345 D 54321EDCBA2.若進棧序列為 1,2,3,4 &#xff0c;進棧…

走進SQL審計視圖——《OceanBase診斷系列》之二

1. 前言 在SQL性能診斷上&#xff0c;OceanBase有一個非常實用的功能 —— SQL審計視圖(gv$sql_audit)。在OceanBase 4.0.0及更高版本中&#xff0c;該功能是 gv$ob_sql_audit。它可以使開發和運維人員更方便地排查在OceanBase上運行過的任意一條SQL&#xff0c;無論這些SQL是成…

字節前端實習一面

1.自我介紹 實習經歷介紹 2.選擇前端的原因 3.如何解決跨域 4.tailwind CSS 這個是我其中一個項目中使用的&#xff0c;但我當時只是當它工具使用的&#xff0c;直接問我實現原理和優勢等等。實現原理我沒回答好&#xff0c;但這個確實是一個好問題 代碼題&#xff1a; 1.let …

層級鎖筆記

注意看test_hierarchy_lock函數 如果thread t2的不注釋&#xff0c;就會報錯。 這是因為層級鎖強調的單個線程內上鎖的順序。 線程t2若已經獲取了hmtx2&#xff0c;再試圖獲取hmtx1就會因為違反層級順序而拋出異常。 #include <mutex> #include <thread> //層級鎖…

kafka文件存儲機制和消費者

1.broker文件存儲機制 去查看真正的存儲文件&#xff1a; 在/opt/module/kafka/datas/ 路徑下 kafka-run-class.sh kafka.tools.DumpLogSegments --files ./00000000000000000000.index 如果是6415那么這個會存儲在563的log文件之中&#xff0c;因為介于6410和10090之間。 2.…

java mysql八股

mysql中如何定位慢查詢 表象&#xff1a;頁面加載過慢、接口壓測響應時間較長&#xff08;超過1秒&#xff09; 可以采用開源工具如Arthas以及Skywalking&#xff0c;使用skywalking可以檢測出哪個接口過慢。同時可以在mysql中開啟慢日志查詢&#xff0c;設置值為2秒&#xff0…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的行人車輛檢測與計數(Python+PySide6界面+訓練代碼)

摘要&#xff1a;開發行人車輛檢測與計數系統對于提升城市交通管理和監控系統的效率至關重要。本篇博客詳細介紹了如何利用深度學習構建一個行人車輛檢測與計數系統&#xff0c;并提供了完整的實現代碼。該系統基于強大的YOLOv8算法&#xff0c;并結合了YOLOv7、YOLOv6、YOLOv5…

[Java 探索者之路] 一個大廠都在用的分布式任務調度平臺

分布式任務調度平臺是一種能夠在分布式計算環境中調度和管理任務的系統&#xff0c;在此環境下&#xff0c;各個任務可以在獨立的節點上運行。它有助于提升資源利用率&#xff0c;增強系統擴展性以及提高系統對錯誤的容忍度。 文章目錄 1. 分布式任務調度平臺1. 基本概念1.1 任…

Linux文本處理三劍客:sed

在Linux操作系統中&#xff0c;grep、sed、awk被稱為文本操作“三劍客”&#xff0c;上一期中&#xff0c;我們將詳細介紹grep的基本使用方法&#xff0c;希望能夠幫助到有需要的朋友&#xff0c;現在&#xff0c;我們繼續學習sed。 我會參考官方文檔來做翻譯理解。下面正式開…

使用Java同步Linux服務器時間

前言 公司客戶線上服務器采用的是UOS系統&#xff0c;實施發現系統不會同步時間&#xff0c;并且時間有真實時間有偏差&#xff0c;本意想安裝NTP授時服務&#xff0c;結果發現UOS安裝NTP都要折騰好久&#xff0c;遂采用Java來曲線救國了。 添加依賴 <dependency><…

Java基于SpringBoot的旅游網站的設計與實現論文

目 錄 摘 要 2 Abstract 3 1.1 課題開發的背景 4 1.2 課題研究的意義 4 1.3 研究內容 5 第二章 系統開發關鍵技術 6 2.1 JSP技術介紹 6 2.2 JAVA簡介 6 2.3 MyEclipse開發環境 7 2.4 Tomcat服務器 7 2.5 Spring Boot框架 7 2.6 MySQL數據庫 8 第三章 系統分析 9 3.1 系統可行性…

實踐航拍小目標檢測,基于YOLOv8全系列【n/s/m/l/x】參數模型開發構建無人機航拍場景下的小目標檢測識別分析系統

關于無人機相關的場景在我們之前的博文也有一些比較早期的實踐&#xff0c;感興趣的話可以自行移步閱讀即可&#xff1a; 《deepLabV3Plus實現無人機航拍目標分割識別系統》 《基于目標檢測的無人機航拍場景下小目標檢測實踐》 《助力環保河道水質監測&#xff0c;基于yolov…

使用 llama.cpp 在本地部署 AI 大模型的一次嘗試

對于剛剛落下帷幕的2023年,人們曾經給予其高度評價——AIGC元年。隨著 ChatGPT 的火爆出圈,大語言模型、AI 生成內容、多模態、提示詞、量化…等等名詞開始相繼頻頻出現在人們的視野當中,而在這場足以引發第四次工業革命的技術浪潮里,人們對于人工智能的態度,正從一開始的…

JVM(5)

垃圾回收相關 垃圾收集器 警告:純八股文! 如果說上面我們講的收集算法是內存回收的方法論,那么垃圾收集器就是內存回收的具體體現. 垃圾收集器的作用:垃圾收集器是為了保證程序能夠正常,持久運行的一種技術,它是將程序中不用的死亡對象也就是垃圾對象進行清除,從而保證新的…