当前位置: 首页 > news >正文

Leetcode 2867. Count Valid Paths in a Tree

  • Leetcode 2867. Count Valid Paths in a Tree
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:2867. Count Valid Paths in a Tree

1. 解题思路

这一题思路上的话由于要求路径上有且仅有一个质数点,因此,一个直接的思路就是考察所有质数的点作为中心点时,其辐射出去的非质数点的个数。

假设一个质数点 p p p上有 k k k个合数子节点,然后每一个合数子节点对应的只包含合数的子树当中的节点个数分别为 n 1 , ⋯ n k n_1, \cdots n_k n1,nk个,那么,包含且仅包含 p p p的路径个数为:

  1. p p p作为路径的一个节点: N = ∑ i = 1 k n i N = \sum\limits_{i=1}^{k}n_i N=i=1kni
  2. p p p作为路径的一个中间节点: N = ∑ i = 1 k ∑ j = 1 , j ≠ i k n i × n j = ∑ i = 1 k n i ( ∑ j = 1 k n j − n i ) / 2 N = \sum\limits_{i=1}^{k}\sum\limits_{j=1, j\neq i}^{k} n_i \times n_j=\sum\limits_{i=1}^{k}n_i(\sum\limits_{j=1}^{k}n_j - n_i) / 2 N=i=1kj=1,j=ikni×nj=i=1kni(j=1knjni)/2

由此,问题就转化为只要求得每一个质数节点 p p p周围相邻的合数节点 u u u作为根节点时的只包含合数节点的子树的节点的个数。

而这个问题只需要用一个深度优先遍历就可以完成了。当然,为了优化执行效率,我们加上了一个cache来对其进行优化。

2. 代码实现

给出最终的python代码实现如下:

@lru_cache(None)
def get_primes():n = 10**5status = [0 for _ in range(n)]primes = []for i in range(2, n):if status[i] == 1:continueprimes.append(i)for j in range(i, n, i):status[j] = 1return primesPRIMES = get_primes()class Solution:def countPaths(self, n: int, edges: List[List[int]]) -> int:if n == 1:return 0primes = PRIMES[:bisect.bisect_right(PRIMES, n)]prime_set = set(primes)graph = defaultdict(list)for u, v in edges:graph[u].append(v)graph[v].append(u)@lru_cache(None)def dfs(u, pre):res = 1for v in graph[u]:if v != pre and v not in prime_set:res += dfs(v, u)return resdef query(u):nodes = [dfs(v, -1) for v in graph[u] if v not in prime_set]res = 0s = sum(nodes)for k in nodes:res += k * (s-k)return res // 2 + sreturn sum(query(u) for u in primes)

提交代码评测得到:耗时1683ms,占用内存71.2MB。

http://www.lryc.cn/news/175217.html

相关文章:

  • Jtti:Ubuntu下如何创建XFS文件系统的LVM
  • 做销售管理分析需要看哪些关键指标?
  • 【Python】自动完成手写字体图片贴入以及盖章工具
  • 基于Xml方式Bean的配置-初始化方法和销毁方法
  • 实时更新进度条:JavaScript中的定时器和异步编程技巧
  • 【简单图论】CF898 div4 H
  • 【大虾送书第十一期】适合新手自学的网络安全基础技能“蓝宝书”:《CTF那些事儿》
  • IDEA安装离线插件后重启无法打开
  • 论软件的可靠性设计
  • AG35学习笔记(一):debug串口抓取模组log、debug串口测试AT指令、echo命令通过串口发送16进制数据
  • Python进阶学习----一闭三器
  • C/S架构学习之TCP客户端
  • 系统集成|第十二章(笔记)
  • 图神经网络(GNN)最新顶会论文汇总【附源码】
  • 【算法】算法设计与分析 课程笔记 第二章 递归与分治策略
  • Java客户端_Apache Curator操作Zookeeper
  • 14:00面试,14:07就出来了,问的问题有点变态
  • 《你好,C语言》:从另一个视角学习并重新审视C语言的意义
  • 信创之国产浪潮电脑+统信UOS操作系统体验1:硬件及软件常规功能支持情况介绍
  • JAVA学习-全网最详细
  • 基于物联网的农村地区智能微电网系统(Simulink)
  • JavaScript系列从入门到精通系列第九篇:JavaScript中赋值运算符和关系运算符以及Unicode编码介绍
  • 租用独立服务器有哪些常见的误区?
  • 【学习笔记】POJ 3834 graph game
  • 无监督学习算法Kmeans
  • 区块链(4):区块链技术模型介绍
  • go语言 rune 类型
  • DS18B20温度传感器
  • LeetCode322. 零钱兑换
  • AUTOSAR扫盲贴--不是黑神话【基本概念和方法论】