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

给你一个整数数组 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);
    }
};
相关推荐
_Minato_8 分钟前
数据结构知识整理——复杂度的计算
数据结构·经验分享·笔记·算法·软考
listhi52010 分钟前
针对燃油运输和车辆调度问题的蚁群算法MATLAB实现
前端·算法·matlab
月明长歌26 分钟前
【码道初阶】【LeetCode 102】二叉树层序遍历:如何利用队列实现“一层一层切蛋糕”?
java·数据结构·算法·leetcode·职场和发展·队列
星诺算法备案37 分钟前
读懂大模型备案流程,开启技术安全应用新征程
人工智能·算法·推荐算法·备案
Loo国昌41 分钟前
大型语言模型推理范式演进:从提示工程到思维算法
人工智能·算法·语言模型·自然语言处理
代码游侠1 小时前
学习笔记——线程控制 - 互斥与同步
linux·运维·笔记·学习·算法
yaoh.wang1 小时前
力扣(LeetCode) 66: 加一 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
聆风吟º1 小时前
【数据结构手札】顺序表实战指南(一):线性表定义 | 顺序表定义
数据结构·顺序表·线性表
wanderist.1 小时前
2025年蓝桥杯省赛C++大学A组
c++·算法·蓝桥杯
啊董dong2 小时前
noi-2025年12月16号作业
数据结构·c++·算法·noi