题面

有两个长为

n

n

n 的序列

a

a

a 和

b

b

b,至多反转

a

a

a 的一个子区间,最大化

i

=

1

n

a

i

b

i

\sum_{i=1}^na_i\cdot b_i

∑i=1n​ai​⋅bi​ 并输出这个值。

1

n

5000

1\leq n\leq5000

1≤n≤5000,答案不会爆 long long

题解

绝大部分人都在考场上用的是官方题解的做法,基本没有什么别的做法了,如果有,那估计就是提交榜单最末尾那些1900+ ms的做法吧。

数据非常小,再加上又是Div2,让人不禁想起暴力做法。朴素的暴力是枚举要翻转的区间

[

l

,

r

]

[l,r]

[l,r] ,然后把它带给答案的变化量加上,取最优输出。

这样是

O

(

n

3

)

O(n^3)

O(n3) 的,过不了。为什么这个暴力不可行,因为我们每次计算区间

[

l

,

r

]

[l,r]

[l,r] ,都要把整个

[

l

,

r

]

[l,r]

[l,r] 模拟翻转一遍在计算答案,这是低效的。

只要我们注意到

[

l

,

r

]

[l,r]

[l,r] 的答案可以从

[

l

+

1

,

r

1

]

[l+1,r-1]

[l+1,r−1] 的答案

O

(

1

)

O(1)

O(1) 转移过来,我们就解决这个问题了。这很好理解,因为这两个区间的旋转中心相等,它们的模拟翻转过程只有最边上不同。

你可以暴力从每个旋转中心往外扩展计算,也可以用 Dynamic Programming 仿照上面说的转移写。都是

O

(

n

2

)

O(n^2)

O(n2) 的,差别不大。

CODE

#include<set>
#include<queue>
#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 5005
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
LL a[MAXN],b[MAXN];
int main() {
n = read();
LL sum = 0;
for(int i = 1;i <= n;i ++) a[i] = read();
for(int i = 1;i <= n;i ++) {
b[i] = read(); sum += a[i] * b[i];
}
LL ans = sum;
for(int i = 1;i <= n;i ++) {// 从中心扩展
LL sm = sum;
for(int j = i-1,k = i+1;j > 0 && k <= n;j --,k ++) { // 长度为奇数,中心是个点
sm -= a[j]*b[j] + a[k]*b[k];
sm += a[j]*b[k] + a[k]*b[j];
ans = max(ans,sm);
}
sm = sum;
for(int j = i,k = i+1;j > 0 && k <= n;j --,k ++) { // 长度为偶数,中心是个分界线
sm -= a[j]*b[j] + a[k]*b[k];
sm += a[j]*b[k] + a[k]*b[j];
ans = max(ans,sm);
}
}
printf("%lld\n",ans);
return 0;
}

[CF1519D] Maximum Sum of Products (暴力)的更多相关文章

  1. [LeetCode] Maximum Sum of 3 Non-Overlapping Subarrays 三个非重叠子数组的最大和

    In a given array nums of positive integers, find three non-overlapping subarrays with maximum sum. E ...

  2. 689. Maximum Sum of 3 Non-Overlapping Subarrays三个不重合数组的求和最大值

    [抄题]: In a given array nums of positive integers, find three non-overlapping subarrays with maximum ...

  3. 【leetcode】1031. Maximum Sum of Two Non-Overlapping Subarrays

    题目如下: Given an array A of non-negative integers, return the maximum sum of elements in two non-overl ...

  4. POJ2479 Maximum sum[DP|最大子段和]

    Maximum sum Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 39599   Accepted: 12370 Des ...

  5. ural 1146. Maximum Sum

    1146. Maximum Sum Time limit: 0.5 secondMemory limit: 64 MB Given a 2-dimensional array of positive ...

  6. UVa 108 - Maximum Sum(最大连续子序列)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

  7. 最大子矩阵和 URAL 1146 Maximum Sum

    题目传送门 /* 最大子矩阵和:把二维降到一维,即把列压缩:然后看是否满足最大连续子序列: 好像之前做过,没印象了,看来做过的题目要经常看看:) */ #include <cstdio> ...

  8. URAL 1146 Maximum Sum(最大子矩阵的和 DP)

    Maximum Sum 大意:给你一个n*n的矩阵,求最大的子矩阵的和是多少. 思路:最開始我想的是预处理矩阵,遍历子矩阵的端点,发现复杂度是O(n^4).就不知道该怎么办了.问了一下,是压缩矩阵,转 ...

  9. ural 1146. Maximum Sum(动态规划)

    1146. Maximum Sum Time limit: 1.0 second Memory limit: 64 MB Given a 2-dimensional array of positive ...

随机推荐

  1. python中 OS模块中 os.path.join() 函数用法简介

    基础用法 os.path.join() 用于拼接文件的路径,可以传入多个待拼接的路径 若各个路径之间不存在 " / ", 则其会自动为各个路径之间增加连接符 " / &q ...

  2. JS:||运算符

    ||逻辑运算符 ||这个符号在开发中 往往是优化的代码最常用的js符号: 当用||连接语句时,回将前后语句变为Boolean类型,再进行运算: 1.当||前面条件为false,不管后面是true/fa ...

  3. React技巧之打开文件输入框

    原文链接:https://bobbyhadz.com/blog/react-open-file-input-on-button-click 作者:Borislav Hadzhiev 正文从这开始~ 总 ...

  4. RPA纳税申报机器人

    1.机器人开始工作 2.机器人打开企业内部税务平台,自动下载报税底表 3.机器人自动登录地方税务局,填写报税数据 手工报税10分钟/3个表 VS 机器人报税时间2分钟/3个表 处理时间缩短80% 报税 ...

  5. Failed to Setup IP tables: Unable to enable SKIP DNAT rule: (iptables failed: iptables --wait -t nat -I DOCKER -i br-b1938128a963

    报错信息:Failed to Setup IP tables: Unable to enable SKIP DNAT rule:  (iptables failed: iptables --wait ...

  6. Nginx通过bat文件快速启动停止

    新建文本文件NginxRun.bat.(名字无所谓,后缀名得是bat) 将以下代码复制到bat文件中即可. @echo off ::进入D盘 d: ::进入nginx目录 这里是自己的nginx目录 ...

  7. CF1042E Vasya and Magic Matrix 题解

    题目链接 思路分析 看到题目中 \(n,m \leq 1000\) ,故直接考虑 \(O(n^2)\) 级别做法. 我们先把所有的点按照 \(val\) 值从小到大排序,这样的话二维问题变成序列问题. ...

  8. 『现学现忘』Git后悔药 — 29、版本回退git reset --mixed命令说明

    git reset --mixed commit-id命令:回退到指定版本.(mixed:混合的,即:中等回退.) 该命令不仅修改了分支中HEAD指针的位置,还将暂存区中数据也回退到了指定版本. 但是 ...

  9. do-while循环和三种循环的区别

    循环语句3--do...while do...while循环格式 初始化表达式① do{ 循环体③ 步进表达式④ }while(布尔表达式②); 执行流程 执行顺序:①③④>②③④>②③④ ...

  10. C++对象的应用

    本篇文章将介绍对象数组,对象的动态分配以及对象在函数中的应用. 一.对象数组 1.对象数组的定义和初始化 定义对象数组与定义普通数组的语法形式基本相同.如定义一个Square obj[3]:表示一个正 ...