力扣每日一题:可被三整除的最大和

给你一个整数数组 nums,请你找出并返回能被三整除的元素 最大和

思路:

最开始考虑的是用01背包问题,对每个元素动态取舍,最后找到最大值。但感觉用数组一直存,可能会爆炸,因为和可能会很大。

因此选择动态递归的方式,找到取前i个和取前i+1个元素的关系。

会发现:假如现在对于前i个元素,可以被三除余j,则对于第i个元素x,如果取了,那么要在前i-1个元素中,找到被三除余j-x。如果不取,就是在前i-1个元素中找到被三除余j。因此可以得到关系式,然后用这个关系求解即可。

然后要考虑的是边界条件,就是当i<0的情况,此时对于前-1个元素,无疑只能找除3余0的,余1和余2均是不存在,因此设定余1余2都是负无穷,这样就不会取到了。

复制代码
class Solution {
public:
    int maxSumDivThree(vector<int>& nums) {
        const int n=nums.size();
        int memo[n][3];
        memset(memo,-1,sizeof(memo));
        auto dfs=[&](auto &&dfs,int i,int j)->int{
        if(i<0)return j?INT_MIN:0;
        int &res=memo[i][j];
        if(res!=-1)return res;
        return res=max(dfs(dfs,i-1,j),dfs(dfs,i-1,(dfs,j+nums[i])%3)+nums[i]);
        };

        return dfs(dfs,n-1,0);
    }
};
相关推荐
闲猿类1 小时前
嵌入式第九天学习
linux·c语言·学习·算法·嵌入式
轻微的风格艾丝凡1 小时前
光伏 MPPT 算法介绍
人工智能·算法·光伏
浪子不回头4152 小时前
经典数据结构-哈希链表-LRU
数据结构·链表·哈希算法
zzzsde2 小时前
【C++】哈希表实现
数据结构·c++·哈希算法·散列表
无敌最俊朗@2 小时前
力扣hot100-环形链表(2)142
算法·leetcode·链表
Elias不吃糖3 小时前
LeetCode每日一练(189, 122)
c++·算法·leetcode
w***37513 小时前
SpringMVC 请求参数接收
前端·javascript·算法
小猪咪piggy3 小时前
【算法】day 19 leetcode 100 矩阵+贪心
算法·leetcode·矩阵
-森屿安年-3 小时前
LeetCode 11. 盛最多水的容器
开发语言·c++·算法·leetcode