码迷,mamicode.com
首页 > 编程语言 > 详细

【JavaScript】Leetcode每日一题-最大整除子集

时间:2021-04-24 11:53:00      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:赋值   fill   amp   存在   length   for   理解   组成   每日一题   

【JavaScript】Leetcode每日一题-最大整除子集

【题目描述】

给你一个由 无重复 正整数组成的集合 nums ,请你找出并返回其中最大的整除子集 answer ,子集中每一元素对(answer[i], answer[j])都应当满足:
answer[i] % answer[j] == 0 ,或
answer[j] % answer[i] == 0
如果存在多个有效解子集,返回其中任何一个均可。

示例1:

输入:nums = [1,2,3]
输出:[1,2]
解释:[1,3] 也会被视为正确答案。

示例2:

输入:nums = [1,2,4,8]
输出:[1,2,4,8]

提示:

1 <= nums.length <= 1000
1 <= nums[i] <= 2 * 10^9
nums 中的所有整数 互不相同

【分析】

  • 思路:

    可以根据代码理解。

    具体请参见三叶姐姐题解

  • /**
     * @param {number[]} nums
     * @return {number[]}
     */
    var largestDivisibleSubset = function(nums) {
        nums.sort(function(a, b){return a>b?1:-1;});  //数组排序(从小到大,有序集
        var len = nums.length;
        var dp = new Array(len).fill(0);  //dp[i]表示从0到i包括第i+1个数时,最大集合
        var back = new Array(len).fill(0); //back[i]用以回溯可属于同一集合的元素
        for(var i=0;i<len;i++){  //赋值dp[i]
            var max = 1, pre = i;
            for(var j=0;j<i;j++){  //遍历i前元素,寻找满足的最大dp[j],并记录下来用以回溯
                if(dp[j]+1 > max && nums[i] % nums[j] == 0){
                    max = dp[j]+1;
                    pre = j;
                }
            }
            dp[i] = max;
            back[i] = pre;
        }
    
        var maxIndex = 0, max = 0;
        for(var i=0;i<len;i++){  //遍历dp,寻找最大集合
            if(dp[i] > max){
                maxIndex = i;
                max = dp[i];
            }
        }
    
        var ans = new Array(max);
        for(var i=0;i<max;i++){  //回溯,寻找最大集合元素
            ans[i] = nums[maxIndex];
            maxIndex = back[maxIndex];
        }
    
        return ans;
    };
    

    技术图片

【JavaScript】Leetcode每日一题-最大整除子集

标签:赋值   fill   amp   存在   length   for   理解   组成   每日一题   

原文地址:https://www.cnblogs.com/krnl-dpr/p/14693351.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!