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

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

文章目录

1、描述

给你一个由 无重复 正整数组成的集合 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]

来源:力扣(LeetCode)

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2、关键字

数组,最大,

3、思路

dp两层遍历,求出最长子集的数量,然后使用两个临时变量记录个数,和最大值,

然后再遍历一遍nums,通过最大值和个数来抽取结果集。

4、notes

1、dp数组获取满足条件的个数,然后通过两个临时变量做一些记录,然后再遍历一遍原数组,进行结果集的调出。

2、最后获取结果集的元素的时候,需要满足两个条件,整除,且dp[i]也满足(最大的个数),

5、复杂度

时间:O(n平方)计算数组dp元素,排序是O(nlogn),倒序遍历是O(N)

空间:O(N),dp数组的长度

6、code

class Solution {   public:    vector
largestDivisibleSubset(vector
& nums) { int n = nums.size(); vector
dp (n,1); // 初始化为1 int maxVal = nums[0]; // 最大值 int maxSize = 1; // 结果集的个数 vector
res; sort(nums.begin(),nums.end()); // 排个序 for(int i = 1; i < n; i++){ for(int j = 0; j
=0; i--){ if(maxVal>=nums[i] && maxVal % nums[i] == 0){ res.push_back(nums[i]); } }*/ for (int i = n - 1;i >= 0,maxSize > 0; i--){ // 个数满足,从右往左 if(dp[i] == maxSize && maxVal % nums[i] == 0){ // 个数满足,且符合整除,这两个条件才是一个结果 res.push_back(nums[i]); maxVal = nums[i]; // 这里不写就错,更新最大值,变得越来越小 maxSize--; // 这里也更新一下 } } return res; }};
你可能感兴趣的文章
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NiuShop开源商城系统 SQL注入漏洞复现
查看>>
NI笔试——大数加法
查看>>
NLog 自定义字段 写入 oracle
查看>>
NLog类库使用探索——详解配置
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP 模型中的偏差和公平性检测
查看>>
Vue3.0 性能提升主要是通过哪几方面体现的?
查看>>
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP、CV 很难入门?IBM 数据科学家带你梳理
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP入门(六)pyltp的介绍与使用
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP度量指标BELU真的完美么?
查看>>
NLP的不同研究领域和最新发展的概述
查看>>
NLP的神经网络训练的新模式
查看>>
NLP采用Bert进行简单文本情感分类
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP项目:维基百科文章爬虫和分类【02】 - 语料库转换管道
查看>>