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

  示例 1:

  输入:nums = [3,6,5,1,8]
  输出:18
  解释:选出数字 3, 6, 1 和 8,它们的和是 18(可被 3 整除的最大和)。

  这道题是第163周竞赛的一道题目,难度中等,边学别人的解题方法,边记录吧!

  

方案一、不妨设dp[i] 代表 选取的数字累加和 模3 = i 的数字和  

  假定nums[i] % 3 = 1 ,那么,和 前面选取的数字和模 3 = 2 的数相加,就可以模3为 0 ,表达起来就是 dp[0] = max(dp[0], nums[i] + dp[2])依次类推,只要不断更新 dp 数组即可,注意一点,更新的时候要保存上一个状态的值,避免后续更新的时候重复影响。

  

 #include <iostream>
#include <vector>
#include <algorithm>
using namespace std; int maxSumDivThree(vector<int>& nums) {
int dp[] = { , , };
int i;
cout << "┌───────┬───────┬───────┐" << endl;
for (i = ; i < nums.size(); i++)
{
//依次判断nums[i]
int mod = nums[i] % ;
int a = dp[( + - mod) % ];//保留上一步的值,避免后续相加影响
int b = dp[( + - mod) % ];
int c = dp[( + - mod) % ]; if (a||mod == ) dp[] = max(dp[], a + nums[i]);
if (b||mod == ) dp[] = max(dp[], b + nums[i]);
if (c||mod == ) dp[] = max(dp[], c + nums[i]);
cout << "│\t" << dp[] << "\t│\t" << dp[] << "\t│\t" << dp[] << "\t│" << endl;
if(i<nums.size()-)
cout << "├───────┼───────┼───────┤" << endl;
else
cout << "└───────┴───────┴───────┘" << endl;
} return dp[];
} vector<int> vc;
int main()
{
int n;
cin >> n;
vc.resize(n);
int i;
for (i = ; i < n; i++)
cin>>vc[i];
cout << endl;
cout << "能被3整除的最大和为:" <<maxSumDivThree(vc) << endl;
return ;
}

理解:(当然这是看的别人的想法,作者https://leetcode-cn.com/u/igamegum/

  先看下运行结果吧,就用上边的实例进行解释:

  

   1、a,b,c是干什么用的?

  a,b,c应该是保留上一步的值,a、b、c的取值如下:

  

  每次均记录了上一步的dp中的值,下一步在计算dp[0]时,dp[0]会发生变化,此时,在计算dp[1]时,用到的dp[0]不再是原始的dp[0],从而造成数据的不一致问题!

  2、if(b || mod == 1)中,为什么还要判断b的值?

  这里的b我理解的是,当它不为0的时候,不过mod值是不是1,我都需要去更新dp[1],因为存在mod是2,需要考虑(2+2)%3=1的情况,同样,mod为0,需要考虑(1+0)%3=1的情况;这里我们去掉试一试,看下结果:

  

  显然,当计算第4层时,数字1%3=1,此时,dp[0]只考虑了mod=0,所以dp[0]没有进行更新,但是数字1+dp[2]也可以构成模3余0的情况,并且和为15,显然比9大!!!

方案二、国外神代码,没解释,等待理解

 class Solution {
public:
int maxSumDivThree(vector<int>& A) {
vector<int> dp = {, INT_MIN, INT_MIN};
for (int a : A) {
vector<int> dp2 = {, , };
for (int i = ; i < ; ++i)
dp2[(i + a) % ] = max(dp[(i + a) % ], dp[i] + a);
dp = dp2;
}
return dp[];
}
};

理解了之后回来更新~~~

Leetcode 1262. 可被三整除的最大和的更多相关文章

  1. LeetCode 5365. 可被三整除的最大和 Greatest Sum Divisible by Three

    地址 https://www.acwing.com/solution/leetcode/content/6340/ 题目描述给你一个整数数组 nums,请你找出并返回能被三整除的元素最大和. 示例 : ...

  2. 【JavaScript】Leetcode每日一题-最大整除子集

    [JavaScript]Leetcode每日一题-最大整除子集 [题目描述] 给你一个由 无重复 正整数组成的集合 nums ,请你找出并返回其中最大的整除子集 answer ,子集中每一元素对(an ...

  3. [LeetCode] 3Sum Closest 最近三数之和

    Given an array S of n integers, find three integers in S such that the sum is closest to a given num ...

  4. LeetCode 15. 3Sum(三数之和)

    Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...

  5. LeetCode第二天&第三天

    leetcode 第二天 2017年12月27日 4.(118)Pascal's Triangle JAVA class Solution { public List<List<Integ ...

  6. [LeetCode] Self Dividing Numbers 自整除数字

    A self-dividing number is a number that is divisible by every digit it contains. For example, 128 is ...

  7. [LeetCode] 259. 3Sum Smaller 三数之和较小值

    Given an array of n integers nums and a target, find the number of index triplets i, j, k with 0 < ...

  8. 【LeetCode】15、三数之和为0

    题目等级:3Sum(Medium) 题目描述: Given an array nums of n integers, are there elements a, b, c in nums such t ...

  9. 【LeetCode】15. 3Sum 三数之和

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 个人公众号:负雪明烛 本文关键词:3sum, 三数之和,题解,leetcode, 力扣,P ...

随机推荐

  1. codis集群搭建笔记

    一.安装Linux虚拟机 二.安装go运行环境 https://www.cnblogs.com/xmzncc/p/6218694.html wget http://mirrors.flysnow.or ...

  2. win10安装MySQL5.6.

    我分了两种下载安装的方式给大家看,注意数据库这个东西不在乎版本是不是最新,在乎的是够稳定,现在公司中常用的是mysql5.5和mysql5.6的版本,我现在就用mysql5.6的版本给大家来演示一下: ...

  3. 配置DirectX SDK开发环境

    创建工程 选择空工程 添加源文件 添加DirectX SDK测试程序 属性配置 添加头文件和库文件路径 D:\Microsoft DirectX SDK (February 2010)\Include ...

  4. wc.exe个人项目

    1.GitHub项目 https://github.com/Littlehui3/wc 2.用时表格 PSP2.1 任务内容 计划完成需要的时间(min) 实际完成需要的时间(min) Plannin ...

  5. 安装Docker报container-selinux >= 2.9错

    Docker装了无数次,还是会遇到如此熟悉的问题,知道他是版本需要更新,但是就是找不到对应的,在网上找了差不多一个下午都没弄好.发现平时还是要多动脑子才行,既然知道是版本需要更新,那么到官网直接找版本 ...

  6. js 字符串换行 显示 使用 \ 转义

     js 字符串 有没有 像C# @ 那种 换行也可以显示的方法\ 

  7. sqlmap基本信息及参数使用方法

    当给sqlmap这么一个url的时候,它会: 1.判断可注入的参数 2.判断可以用那种SQL注入技术来注入 3.识别出哪种数据库 4.根据用户选择,读取哪些数据 sqlmap支持五种不同的注入模式: ...

  8. apache2.4

    介绍 Apache HTTP server是Apache软件基金会的一个开源的网页服务器,可以运行在几乎所有广泛使用的计算机平台上,由于跨平台和安全性被广泛使用,是目前最流行的web服务器软件之一,目 ...

  9. CentOS6.7编译安装mysql5.6

    可能因为有各种情况,无法通过yum安装mysql,这里记录一下编译安装的简单步骤 使用yum安装一些依赖 yum -y install make gcc-c++ cmake bison-devel  ...

  10. 设置 Jupyter notebook 工作空间 / 默认路径

    常用的启动 Jupyter notebook 的两种方式是:命令行窗口启动和开始菜单启动.设置 Jupyter notebook 的默认路径也有两种常用方式: 修改配置文件 设置快捷方式. 1 通过修 ...