线性DP--BOX

还没学,等学完再仔细写。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll a[1000010];
ll vis[1000010];
ll f[1000010][3];
int main()
{
    ll n,m;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
    }
    for(int i=1;i<=n;i++)
    {
        cin>>vis[i];
    }
    for(int i=1;i<=n;i++)
    {
        if(vis[i]==1)
        {
            f[i][0]=max(f[i-1][0]+a[i-1],f[i-1][1]);
            f[i][1]=max(f[i-1][0],f[i-1][1])+a[i];
            f[i][2]=max(f[i-1][0],max(f[i-1][1],f[i-1][2]))+a[i+1];
        }
        if(vis[i]==0)
        {
            f[i][0]=max(f[i-1][0],f[i-1][1]);
            f[i][1]=f[i-1][2];
            //f[i][2]=
        }
    }

    cout<<max(f[n][0],max(f[n][1],f[n][2]))<<endl;
    return 0;
}
相关推荐
·心猿意码·13 小时前
OCCT源码解析(二):NCollection解析
数据结构·c++
进击的荆棘13 小时前
C++起始之路——C++11(下)
开发语言·c++·c++11·lambda
Lucky_ldy13 小时前
C语言学习: 自定义类型—联合和枚举
c语言·学习·算法
gumichef13 小时前
栈和队列(2)
数据结构·算法·链表
许长安13 小时前
C++ 原子变量与内存序:从std::atomic到release/acquire
开发语言·数据结构·c++·经验分享·笔记
sanqima13 小时前
mscomm32.ocx串口插件的注册方法
c++·串口通信·ocx插件
进击的荆棘13 小时前
递归、搜索与回溯——综合(下)
c++·算法·leetcode·深度优先·dfs
不知名的忻13 小时前
归并排序(Java)
java·算法·排序算法
代码中介商15 小时前
C++ STL 容器完全指南(二):vector 深入与 stringstream 实战
开发语言·c++
YUDAMENGNIUBI16 小时前
day20_逻辑回归
算法·机器学习·逻辑回归