标签:04 22 nums int len vector 368 ans dp
368. 最大整除子集
LeetCode每日一题 2021/4/23
class Solution{
public:
vector<int> largestDivisibleSubset(vector<int> &nums){
int len = nums.size();
if(len < 2) return nums;
sort(nums.begin(), nums.end());
vector<int> dp(len, 1);
vector<int> path(len, -1);
int maxIndex = -1, maxLen = 0;
for(int i = 0; i < len; 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;
path[i] = j;
}
}
}
if(dp[i] > maxLen){
maxLen = dp[i];
maxIndex = i;
}
}
int index = maxIndex;
vector<int> ans;
while(index != -1){
ans.push_back(nums[index]);
index = path[index];
}
return ans;
}
};
//解法2
class Solution{
public:
vector<int> largestDivisibleSubset(vector<int> &nums){
int len = nums.size();
if(len < 2) return nums;
sort(nums.begin(), nums.end());
using PII = pair<int, int>;
PII dp[n];
for(int i = 0; i < len; i++){
PII rec(1, i);
for(int j = 0; j < i; j++){
if(nums[i] % nums[j] == 0 && dp[j].first + 1 > rec.first){
rec = {dp[j].first + 1, j};
}
}
dp[i] = rec;
}
int idx = max_element(dp, dp + len) - dp;
int val = dp[idx].first;
vector<int> ans;
while(val--){
ans.push_back(nums[idx]);
idx = dp[idx].second;
}
return ans;
}
};
标签:04,22,nums,int,len,vector,368,ans,dp 来源: https://blog.csdn.net/LushMountain/article/details/116042195
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。