博客
关于我
最大整除子集
阅读量:120 次
发布时间:2019-02-26

本文共 1475 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要找到一个由给定数组中的无重复正整数组成的最大整除子集。子集中的每一对元素都必须满足互相整除的条件。

方法思路

我们可以使用动态规划的方法来解决这个问题。具体步骤如下:

  • 排序数组:首先对数组进行排序,这样可以方便后续处理,较大的数在后面。
  • 初始化动态规划数组:定义一个动态规划数组 dp,其中 dp[i] 表示以 nums[i] 为最大的数的子集的大小。初始时,每个元素都初始化为1,因为每个数本身可以作为一个子集的最小形式。
  • 计算动态规划数组:遍历每个数 nums[i],然后对于每个 nums[i],遍历之前的所有数 nums[j](j < i),检查 nums[i] 是否能被 nums[j] 整除。如果能,那么 dp[i] = max(dp[i], dp[j] + 1)。这样,dp[i] 就记录了以 nums[j] 为最大的子集的大小,再加上当前的 nums[i],形成一个更大的子集。
  • 构建结果集:从右到左遍历数组,寻找 dp[i] 等于当前最大子集大小,并且能被当前最大值整除的数。将这些数加入结果集中,并更新当前最大值和子集大小。
  • 解决代码

    #include 
    #include
    using namespace std;vector
    largestDivisibleSubset(vector
    nums) { int n = nums.size(); if (n == 0) return vector
    (); sort(nums.begin(), nums.end()); vector
    dp(n, 1); int maxVal = nums[n-1]; int maxSize = 1; for (int i = 1; i < n; ++i) { for (int j = 0; j < i; ++j) { if (nums[i] % nums[j] == 0) { if (dp[i] < dp[j] + 1) { dp[i] = dp[j] + 1; } if (dp[i] > maxSize) { maxSize = dp[i]; maxVal = nums[i]; } } } } vector
    res; int currentMaxSize = 0; for (int i = n-1; i >= 0; --i) { if (dp[i] > currentMaxSize) { currentMaxSize = dp[i]; if (res.empty() || !res.back() % nums[i] == 0) { res.push_back(nums[i]); } } } return res;}

    代码解释

  • 排序数组:使用 sort 函数对数组进行排序,以便后续处理。
  • 初始化动态规划数组dp 数组初始化为1,表示每个数本身可以作为一个子集。
  • 计算动态规划数组:双重循环遍历数组,更新 dp 数组记录最大子集大小。
  • 构建结果集:从右到左遍历数组,找到满足条件的数并加入结果集中,确保结果集中的数互相整除,并且大小最大。
  • 通过这种方法,我们可以高效地找到满足条件的最大整除子集。

    转载地址:http://jahu.baihongyu.com/

    你可能感兴趣的文章
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用node-red-contrib-image-output节点实现图片预览
    查看>>
    Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 历史
    查看>>
    Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>