题面

有两个长为

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. 1.数据结构《Pytorch神经网络高效入门教程》Deeplizard

    当移动一个数组或向量时,我们需要一个索引:二维数组/矩阵需要两个索引, 比如说标量是零维张量,数组/向量/矢量是一维张量,矩阵是是二维张量,n维数组是n维张量. 如果我们被告知,  假设有一个张量t, ...

  2. LVGL库入门教程01-移植到STM32(触摸屏)

    LVGL库移植STM32 LVGL库简介 LVGL(Light and Versatile Graphics Library)是一个免费.开源的嵌入式图形库,可以创建丰富.美观的界面,具有许多可以自定 ...

  3. 用python这样做,offer还不是拿到手软?

    大家好鸭,我是小熊猫 本篇代码提供者: 自游老师 老师简介:青灯教育金牌讲师3年Python爬虫开发经验七年在线教育经验擅长Python.c等语言曾任职多家互联网公司爬虫工程师.Python讲师 [环 ...

  4. NC16783 [NOIP1998]拼数

    NC16783 [NOIP1998]拼数 题目 题目描述 设有 \(n\) 个正整数(\(n ≤ 20\)),将它们联接成一排,组成一个最大的多位整数. 例如:\(n=3\) 时,\(3\) 个整数 ...

  5. NC23053 月月查华华的手机

    NC23053 月月查华华的手机 题目 题目描述 月月和华华一起去吃饭了.期间华华有事出去了一会儿,没有带手机.月月出于人类最单纯的好奇心,打开了华华的手机.哇,她看到了一片的QQ推荐好友,似乎华华还 ...

  6. nexus org.sonatype.nexus.bootstrap.jetty.JettyServer - Start failed

    INFO [jetty-main-1] *SYSTEM org.sonatype.nexus.bootstrap.jetty.JettyServer - Runningjvm 1 | 2020-04- ...

  7. shell查询prometheus数据

    #shell查询prometheus数据 shell使用curl调用HTTP API执行PromQL /api/v1/query查询某一时刻的数据 查询条件PromSQL复杂时, 传入接口/api/v ...

  8. CSDN 原力(声望,影响力) -- 设计草案

    目标 CSDN 希望成为开发者学习,成长和成就的平台.我们已经有很多功能来支持开发者的职业成长了, 如何衡量成就呢?我们希望用 原力 (以前也叫 影响力,声望) 来体现用户的成就, 并希望用原力来帮助 ...

  9. 基于cornerstone.js的dicom医学影像查看浏览功能

    最近由于项目需求,需要医学影像.dcm文件的预览功能,功能完成后,基于原生Demo做一个开源分享. 心急的小伙伴可以先看如下基于原生js的全部代码: 一.全部代码 <!DOCTYPE html& ...

  10. CentOS 定时计划任务设置

    一.安装crontab服务并设置开机自启 yum install crontabs (centos默认就会带,一般不需要安装) systemctl enable crond (设为开机启动) syst ...