
【java】368. 最大整除子集---使用动态规划,快速解决子问题!!!
发布日期:2021-05-07 02:22:50
浏览次数:17
分类:精选文章
本文共 870 字,大约阅读时间需要 2 分钟。
给你一个由 无重复 正整数组成的集合 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 * 109 nums 中的所有整数 互不相同
代码:public ListlargestDivisibleSubset(int[] nums) { List list=new ArrayList (); if(nums.length==0) { return list; } Arrays.sort(nums); //记录该元素整除元素的个数 int []dp=new int[nums.length]; //记录该元素整除最近的下一个元素的下标 int []index=new int[nums.length]; Arrays.fill(index,-1); int a=0; for(int i=0;i dp[i]) { dp[i]++; index[i]=j; if(dp[i]>dp[a]) { a=i; } } } } while(a!=-1) { list.add(nums[a]); a=index[a]; } return list; }
发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2025年03月27日 16时27分26秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
vue项目通过vue.config.js配置文件进行proxy反向代理跨域
2021-05-08
Linux下安装MySql过程
2021-05-08
android:使用audiotrack 类播放wav文件
2021-05-08
vue通过better-scroll 封装自定义的下拉刷新组件
2021-05-08
android解决:使用多线程和Handler同步更新UI
2021-05-08
Element UI 中动态路由的分析及实现
2021-05-08
使用springMVC配置视图管理器后找不到指定的页面
2021-05-08
杭电 2007 平方和与立方和(输入数据的大小顺序并不能默认)
2021-05-08
十大排序算法之三:插入排序(Python)
2021-05-08
利用Python实现循环队列
2021-05-08
利用递归实现二叉树的前中后序遍历(Python)
2021-05-08
冒泡排序又来啦(C/C++版本)
2021-05-08
python负数存储
2021-05-08
求二维数组中最大值的位置
2021-05-08
python中sort和sorted的区别
2021-05-08
maven安装
2021-05-08
合并两个有序数组
2021-05-08
聊聊我的五一小假期
2021-05-08
面向对象之异常处理:多路捕获
2021-05-08
Python简易五子棋
2021-05-08