2024.4.11力扣每日一题——互质树

2024.4.11

      • 题目来源
      • 我的题解
        • [方法一 深度优先遍历+回溯+存储父节点](#方法一 深度优先遍历+回溯+存储父节点)
        • [方法二 官方深度优先遍历](#方法二 官方深度优先遍历)

题目来源

力扣每日一题;题序:1766

我的题解

方法一 深度优先遍历+回溯+存储父节点

使用一个List存储深度优先遍历过程中的父节点,然后从List的右侧开始遍历,直到与当前节点互质结束。
时间复杂度 :O( n 2 n^2 n2)
空间复杂度:O(n+h)。h是树的高度,表示递归栈的空间

java 复制代码
//会超时
public int[] getCoprimes(int[] nums, int[][] edges) {
    int n=nums.length;
    List<Integer>[] g=createGraph(n,edges);
    int[] res=new int[n];
    res[0]=-1;
    List<Integer> l=new ArrayList<>();
    l.add(0);
    dfs(g,nums,l,res,0,-1);
    return res;
}
public void dfs(List<Integer>[] g,int[] nums,List<Integer> parent,int[] res,int cur,int pre){
    for(int next:g[cur]){
        if(next!=pre){
            res[next]=check(nums,next,parent);
            parent.add(next);
            dfs(g,nums,parent,res,next,cur);
            parent.remove(parent.size()-1);
        }
    }

}
//获取互质的第一个祖先节点
public int check(int[] nums,int cur,List<Integer> parent){
    int res=-1;
    for(int i=parent.size()-1;i>=0;i--){
        if(gcd(nums[cur],nums[parent.get(i)])==1){
            res=parent.get(i);
            break;
        }
    }
    return res;
}
public List<Integer>[] createGraph(int n,int[][] edges){
    List<Integer>[] g=new ArrayList[n];
    for(int i=0;i<n;i++)
        g[i]=new ArrayList<>();
    for(int[] t:edges){
        int from =  t[0];
        int to = t[1];
        g[from].add(to);
        g[to].add(from);
    }
    return g;
}
public int gcd(int x,int y){
    if(y==0)
        return x;
    return gcd(y,x%y);
}
方法二 官方深度优先遍历

没怎么看懂,自己看官方题解

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
LiLiYuan.11 小时前
【Java 6种线程状态】
java·开发语言
foundbug99912 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
itzixiao12 小时前
L1-047 装睡 (5分)[java][python]
java·开发语言·python
chutao12 小时前
EasyPDF 转图片(EasyPdf2Image)—— 本地安全实用的PDF与图片双向互转工具
安全·职场和发展·pdf·创业创新·学习方法
用户2986985301412 小时前
不用无头浏览器,Java 如何将 HTML 转成图片?
java·后端
自我意识的多元宇宙12 小时前
树、森林——树与二叉树的应用(哈夫曼树的构造)
数据结构
Chengbei1113 小时前
红队专属Bing Dork自动化工具,敏感信息侦察效率拉满、自动生成可视化信息泄露审计报告
java·人工智能·安全·web安全·网络安全·自动化·系统安全
海绵宝宝的月光宝盒13 小时前
2-非金属材料
经验分享·笔记·学习·其他·职场和发展·课程设计·制造
敖正炀13 小时前
集合-Set深入解析
java
下次再写13 小时前
Java互联网大厂面试技术问答实战:涵盖Java SE、Spring Boot、微服务及多场景应用
java·数据库·缓存·面试·springboot·microservices·技术问答