小烈送菜

题目描述

小烈一下碰碰车就被乐满地的工作人员抓住了。作为扰乱秩序的惩罚,小烈必须去乐满地里的“漓江村”饭店端盘子。

服务员的工作很繁忙。他们要上菜,同时要使顾客们尽量高兴。一位服务生为 \(n\) 个顾客上菜。这 \(n\) 个顾客坐成一排,小烈从一端的厨房中端出\(n\)盘菜(不要问我为什么小烈能一下子端住 \(2500\) 盘菜,他就是能)为 \(n\) 个顾客各上一道相同的菜。

显然,小烈需要走一个来回,如图:

本来,小烈可以按 \(1,2,3...n\) 的顺序一次给每个顾客上菜,但是,聪明的小烈通过观察发现,每个顾客都有一个开心值 \(H_1\)、\(H_2\)、\(H_3\)...\(H_n\) ,离厨房最近的为 \(H_1\) ,然后依次为 \(H_2\)、\(H_3\)...\(H_n\) 。若小烈给第 \(j\) 位顾客上菜前刚刚为第 \(i\) 位顾客上菜,则第 \(j\) 位就会高兴,产生高兴指数 \(W_j=H_i\times H_j\) 。这样,如果小烈按一定的方式调整上菜顺序,可以得到更高的高兴指数。现在小烈想知道用某一方法可达到的 \(n\) 位顾客高兴指数之和的最大值 \(S\) 。因为顾客越高兴,给小烈的小费越多。第一位上菜的顾客不产生高兴值。

输入格式

第一行一个整数 \(n\) ,顾客的数目。

第二行 \(n\) 个数,第 \(i\) 个数表示第 \(i\) 位顾客的开心值。各个数字用空格隔开。

输出格式

一个数 \(s\) ,为高兴指数的最大值。

样例

样例输入

3
7 1 9

样例输出

72

数据范围与提示

样例解释:从左往右上 \(1\) 的菜,再上 \(9\) 的菜,高兴值是 \(0\times 1+1\times 9\) ,从右往左走回来的时候上 \(7\) 的菜,高兴值是 \(7\times 9\) ,总的高兴值就是 \(72\) 。

对于 \(30\%\) 的数据\(n\leq9,n\in N^+\);

对于 \(70\%\) 的数据\(n\leq1500,n\in N^+\);

对于 \(100\%\) 的数据\(n\leq2500,n\in N^+\);

所有数字小于(含结果) \(2147483648\) ;

思路

题意中的来回两次直接 \(dp\) 的话,还需要记录第一次走的路径,很麻烦。

根据之前的方格取数,我们也可以把这个题转换成两个小烈送菜。

定义 \(dp[i][j]\) 为有两个小烈同时从厨房开始送菜,第一个小烈到达 \(i\) 的位置,第二个小烈到达 \(j\) 的位置,所能取到的最大值。

有一个很重要的性质:\(dp[i][j]=dp[j][i]\)。

第一个小烈送到 \(i\) 的位置,第二个小烈送到 \(j\) 的位置与第一个小烈送到 \(j\) 的位置,第二个小烈送到 \(i\) 的位置所得的结果是相同的。

动态转移方程:

第一个小烈由 \(i\) 送到 \(i+1\) 的位置。

\(dp[i+1][j]=max(dp[i+1][j],dp[i][j]+a[i]*a[i+1])\)

或者第二个小烈由 \(j\) 送到 \(i+1\) 的位置。

\(dp[i][i+1]=max(dp[i][i+1],dp[i][j]+a[j]*a[i+1])\)

根据之前的性质,可以把转移方程转化为:

\(dp[i+1][i]=max(dp[i+1][i],dp[i][j]+a[j]*a[i+1])\)

这样保证了 \(dp[i][j]\) 中的 \(i\) 一定会大于 \(j\),便于处理。

最后在寻找一遍最大值即可。

代码

#include <bits/stdc++.h>
using namespace std; const int maxn=2500+50;
int n,ans;
int a[maxn];
int dp[maxn][maxn]; int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
}
for(int i=1;i<=n;i++){
for(int j=0;j<i;j++){
dp[i+1][j]=max(dp[i+1][j],dp[i][j]+a[i]*a[i+1]);//前面那个处于i位置的小烈送i+1的菜
dp[i+1][i]=max(dp[i+1][i],dp[i][j]+a[j]*a[i+1]);//后面那个处于j位置的小烈送i+1的菜,并根据性质翻转
}
}
for(int i=0;i<n;i++){
ans=max(ans,dp[n][i]+a[n]*a[i]);//前面那个小烈送到n的位置,但是不确定后面那个小烈在哪里,所以以此枚举
}
cout<<ans<<endl;
return 0;
}

小烈送菜——奇怪的dp的更多相关文章

  1. 方格取数(简单版)+小烈送菜(不知道哪来的题)-----------奇怪的dp增加了!

    一.方格取数: 设有N*N的方格图(N<=20),我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0. 某人从图的左上角的A(1,1) 点出发,可以向下行走,也可以向右走,直到到达右下 ...

  2. 线性DP之小烈送菜

    小烈送菜 小烈一下碰碰车就被乐满地的工作人员抓住了.作为扰乱秩序的惩罚,小烈必须去乐满地里的"漓江村"饭店端盘子. 服务员的工作很繁忙.他们要上菜,同时要使顾客们尽量高兴.一位服务 ...

  3. [HNOI2009]双递增序列(洛谷P4728)+小烈送菜(内部训练题)——奇妙的dp

    博主学习本题的经过嘤嘤嘤: 7.22 : 听学长讲(一知半解)--自己推(推不出来)--网上看题解--以为自己会了(网上题解是错的)--发现错误以后又自己推(没推出来)--给学长发邮件--得到正确解法 ...

  4. 青年菜君与小农女送菜商业模式PK

    青年菜君与小农女送菜商业模式PK   对比项 青年菜君 小农女送菜 优势 劣势 开业 2014年3月3日 2013年9月 渠道 地铁捕获用户 写字楼配送 送货 来店面自取 送货到写字楼 菜君 1.减少 ...

  5. BZOJ 4316: 小C的独立集 仙人掌 + 树形DP

    4316: 小C的独立集 Time Limit: 10 Sec  Memory Limit: 128 MB Description 图论小王子小C经常虐菜,特别是在图论方面,经常把小D虐得很惨很惨. ...

  6. [CSP-S模拟测试]:小奇的矩阵(matrix)(DP+数学)

    题目背景 小奇总是在数学课上思考奇怪的问题. 题目描述 给定一个$n\times m$的矩阵,矩阵中的每个元素$a_{i,j}$为正整数.接下来规定:    $1.$合法的路径初始从矩阵左上角出发,每 ...

  7. BZOJ 3437: 小P的牧场 斜率优化DP

    3437: 小P的牧场 Description 背景 小P是个特么喜欢玩MC的孩纸... 描述 小P在MC里有n个牧场,自西向东呈一字形排列(自西向东用1…n编号),于是他就烦恼了:为了控制这n个牧场 ...

  8. bzoj3427小P的牧场(斜率优化dp)

    小P在MC里有n个牧场,自西向东呈一字形排列(自西向东用1…n编号),于是他就烦恼了:为了控制这n个牧场,他需要在某些牧场上面建立控制站,每个牧场上只能建立一个控制站,每个控制站控制的牧场是它所在的牧 ...

  9. uoj132/BZOJ4200/洛谷P2304 [Noi2015]小园丁与老司机 【dp + 带上下界网络流】

    题目链接 uoj132 题解 真是一道大码题,,,肝了一个上午 老司机的部分是一个\(dp\),观察点是按\(y\)分层的,而且按每层点的上限来看可以使用\(O(nd)\)的\(dp\),其中\(d\ ...

随机推荐

  1. 云服务器部署Web项目

    接着上一篇整好MySQL数据库了,部署Web项目的重要一步就完成了,接下来就是整Tomcat发布项目了,这个博主用的是宝塔面板,所以,也很简单,直接在宝塔面板软件商店选择对应的Tomcat版本安装就行 ...

  2. .NET Core Session源码探究

    前言     随着互联网的兴起,技术的整体架构设计思路有了质的提升,曾经Web开发必不可少的内置对象Session已经被慢慢的遗弃.主要原因有两点,一是Session依赖Cookie存放Session ...

  3. zabbix 监控交换机文本/日志信息

    简介 公司有台路由设备,需要每天去核对用户量,查看信息等.为了避免重复的工作量,就通过zabbix来完成这个重复性的工作. 先说下思路,首先要创建一个脚本,能从zabbix-server 或者zabb ...

  4. 常见ie9兼容问题

    公司项目要求需要兼容ie9,开发过程中遇到了许多问题,在这里记录一下,希望可以帮到其他需要的小伙伴. 浏览器兼容性问题无外乎三点,css样式兼容.JavaScript兼容及h5部分标签的兼容.主要介绍 ...

  5. Java 多线程基础(三) start() 和 run()

    Java 多线程基础(三) start() 和 run() 通过之前的学习可以看到,创建多线程过程中,最常用的便是 Thread 类中的 start() 方法和线程类的 run() 方法.两个方法都包 ...

  6. javaCV开发详解之12:视频转apng动态图片实现,支持透明通道,也支持摄像机、桌面屏幕、流媒体等视频源转apng动态图

    wjavaCV系列文章: javacv开发详解之1:调用本机摄像头视频 javaCV开发详解之2:推流器实现,推本地摄像头视频到流媒体服务器以及摄像头录制视频功能实现(基于javaCV-FFMPEG. ...

  7. laravel模板使用

    {{ $var }} - 打印内容 {{ $var or 'default' }} - 打印内容并带一个默认值 {{{ $var }}} - 打印转义内容 {{-- Comment --}} - 注释 ...

  8. 在c++MFC下用PCL显示操作点云文件 MFC对话框显示操作PCL点云

    原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/13115873.html 第一步 下载PCL库  我的版本是1.8.1的 你都要MFC下跑PCL ...

  9. 阿里云Ubuntu配置jdk+tomcat

    阿里云系统环境:Ubuntu 18.04 64位 ssh远程连接工具:Xshell6(如何连接此处不讨论) 一>java jdk安装及环境配置 ​ 1.更新apt-get命令 apt-get - ...

  10. 使用本地http的yum源

    使用http作为本地yum源 场景 在生产环境中,有大概好几十台linux同系统版本的操作系统,为了安装普通软件,现在的做法是向每台机器上上传一个iso镜像,然后将镜像挂在,配置本地的yum源,实现基 ...