bzoj1652: [Usaco2006 Feb]Treats for the Cows_Cynthia_wjyi的博客-程序员宝宝

技术标签: usaco silver  动态规划  

1652: [Usaco2006 Feb]Treats for the Cows

Time Limit: 5 Sec   Memory Limit: 64 MB
Submit: 275   Solved: 212
[ Submit][ Status][ Discuss]

Description

FJ has purchased N (1 <= N <= 2000) yummy treats for the cows who get money for giving vast amounts of milk. FJ sells one treat per day and wants to maximize the money he receives over a given period time. The treats are interesting for many reasons: * The treats are numbered 1..N and stored sequentially in single file in a long box that is open at both ends. On any day, FJ can retrieve one treat from either end of his stash of treats. * Like fine wines and delicious cheeses, the treats improve with age and command greater prices. * The treats are not uniform: some are better and have higher intrinsic value. Treat i has value v(i) (1 <= v(i) <= 1000). * Cows pay more for treats that have aged longer: a cow will pay v(i)*a for a treat of age a. Given the values v(i) of each of the treats lined up in order of the index i in their box, what is the greatest value FJ can receive for them if he orders their sale optimally? The first treat is sold on day 1 and has age a=1. Each subsequent day increases the age by 1.

约翰经常给产奶量高的奶牛发特殊津贴,于是很快奶牛们拥有了大笔不知该怎么花的钱.为此,约翰购置了N(1≤N≤2000)份美味的零食来卖给奶牛们.每天约翰售出一份零食.当然约翰希望这些零食全部售出后能得到最大的收益.这些零食有以下这些有趣的特性:

•零食按照1..N编号,它们被排成一列放在一个很长的盒子里.盒子的两端都有开口,约翰每
  天可以从盒子的任一端取出最外面的一个.
•与美酒与好吃的奶酪相似,这些零食储存得越久就越好吃.当然,这样约翰就可以把它们卖 出更高的价钱.
  •每份零食的初始价值不一定相同.约翰进货时,第i份零食的初始价值为Vi(1≤Vi≤1000).
  •第i份零食如果在被买进后的第a天出售,则它的售价是vi×a.
  Vi的是从盒子顶端往下的第i份零食的初始价值.约翰告诉了你所有零食的初始价值,并 希望你能帮他计算一下,在这些零食全被卖出后,他最多能得到多少钱.

Input

* Line 1: A single integer,

N * Lines 2..N+1: Line i+1 contains the value of treat v(i)

Output

* Line 1: The maximum revenue FJ can achieve by selling the treats

Sample Input

5
1
3
1
5
2

Five treats. On the first day FJ can sell either treat #1 (value 1) or
treat #5 (value 2).

Sample Output

43

OUTPUT DETAILS:

FJ sells the treats (values 1, 3, 1, 5, 2) in the following order
of indices: 1, 5, 2, 3, 4, making 1x1 + 2x2 + 3x3 + 4x1 + 5x5 = 43.

HINT

Source

题解:
dp.f[i][j]=max(f[i+1][j]+a[i]*t,f[i][j-1]+a[j]*t)

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define ll long long
using namespace std;
int read()
{
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
	return x*f;
}
int N,a[2005],f[2005][2005];
int main()
{
    N=read();
    for(int i=1;i<=N;i++)a[i]=read();
    for(int k=1;k<=N;k++)
      for(int i=1;i+k-1<=N;i++)
      {
      	int t=N-k+1,j=i+k-1;
      	f[i][j]=max(f[i+1][j]+t*a[i],f[i][j-1]+t*a[j]);
      }
    cout<<f[1][N]<<endl;
}



版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Cynthia_wjyi/article/details/49404479

智能推荐

c#连接SQL数据库(一)_c# 属性连接sql_天地神仙的博客-程序员宝宝

一、Connection对象概述Connection对象是一个连接对象,主要功能是建立与物理数据库的连接。其主要包括访问数据库的对象类,也可称为数据提供程序。SQL Server ,位于System.Data.SqlClient命名空间ODBC ,位于System.Data.Odbc命名空间OLEDB,位于System.Data.OleDb命名空间Oracle,位于System.Data.OracleClient命名空间根据使用的数据库不同,引入不同的命名空间,然后通过命名空间中的Conne

es6 字符串部分新用法(padStart,padEnd,repeat,startsWith,endsWidth,includes )_不忘初心才得始终的博客-程序员宝宝

//字符串部分新用法//padStartpadEnd//padStart()用于头部补全,即:把ab补全到xxx的头部,如果用来补全的字符串与原字符串,两者的长度之和超过了指定的最小长度,则会截去超出位数的补全字符串。ES2017 引入了字符串补全长度的功能。如果某个字符串不够指定长度,会在头部或尾部补全。padStart()用于头部补全,padEnd()用于尾部补全。...

Anaconda 3 下的 Spyder 的汉化报错处理_liunx中spyder汉化包安装报错_叫我明明就行的博客-程序员宝宝

Anaconda 3 下的 Spyder 的汉化参照原文博客:http://www.lizenghai.com/archives/523.html汉化包下载:https://github.com/kingmo888/Spyder_Simplified_Chinese本人在汉化过程中遇见几个问题,特与大家分享经验。1.运行错误在参照原文博主的方法进行汉化中遇见问题,如下:...

AES-128,192,256位加密解密,其中128位已经测试过_加密ace128 256_tianshi1017的博客-程序员宝宝

package com.test;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.security.NoSuchAlgorithmException;import java

android gson使用--json2对象与对象2json_weixin_33676492的博客-程序员宝宝

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种理想的数据交换格式。   其实,要创建和解析JSON数据,也可以使用GSON来完成。GSON是Google提供的用来在Java对象和JSON数据之间进行映射的Java类库。使用GSON,可以很容易的将一串JSON数据转换为一个J...

随便推点

初始化:编译开发环境并常用工具组件_weixin_33862993的博客-程序员宝宝

# yum -y install \automake make cmake autoconf rpm-build ncurses ncurses-devel ntp \gd cpp gcc gcc-c++ glibc glibc-devel glibc-common glib2 glib2-devel libtool libtool-ltdl-devel \compat-libstd...

Linux ps 命令_linux下arc是什么命令_半个程序员的博客-程序员宝宝

转自:http://linux.cn/thread/12046/1/1/,感谢linux!linux的ps命令是一个查看系统运行的进程的一个最基础的工具。它提供了一个当前进程的快照,还带有一些具体的信息,比如用户id,cpu使用率,内存使用,命令名等,它不会像top或者htop一样实时显示数据。虽然它在功能和输出上更加简单,但它仍然是每个linux新手需要了解和学好的必要进程管理/检测工具

Android wallpape service_FE421504975的博客-程序员宝宝

之前写过一个wallpaper的PPT,现在通过截图方式贴在博客这里与大家分享吧1、2、3、4、5、6、7、8、上面是PPT的一个贴图。下面贴一个整体的一个流程图,可以仔细看看。

如何快速记住BigDecimal中compareTo的1、-1、0的含义_weixin_34291004的博客-程序员宝宝

2019独角兽企业重金招聘Python工程师标准&gt;&gt;&gt; ...

DNA(模拟)_YuanxQAQ的博客-程序员宝宝

题目描述小强从小就喜欢生命科学,他总是好奇花草鸟兽从哪里来的。终于, 小强上中学了,接触到了神圣的名词–DNA.它有一个双螺旋的结构。这让一根筋的小强抓破头皮,“要是能画出来就好了” 小强喊道。现在就请你帮助他吧输入输入包含多组测试数据。第一个整数N(N&lt;=15),N表示组数,每组数据包含两个整数a,b。a表示一个单位的DNA串的行数,a为奇数且 3&lt;=a&lt;=39。b表示重...

Linux管理虚拟IP的方法_fairplay_li的博客-程序员宝宝

一:命令行方式添加与删除1. 在网卡1上添加一个虚IPifconfig eth0:1 192.168.100.10 netmask 255.255.255.0删除刚才添加的虚IPip addr del 192.168.100.10/24 dev eth0  注意这里一定要加掩码,否则会弹出一个警告,如下:“Warning: Executing wildcard deletion

推荐文章

热门文章

相关标签