2018.3.17 模拟赛——(2)删数

2018.3.17 模拟赛——(2)删数

大家好,又见面了,我是全栈君。

题目大意:

给出一个序列x,从左边或者右边删数,使得总价值最大。
删除从i位置到k位置上的所有的数。操作价值为|xi – xk|*(k-i+1),如果只删除一个数,操作价值为这个数的值。

解题思路:

区间dp
动态转移方程为:

f[i][j]=max(f[i][k]+f[k+1][j],f[i][j]);(f[i][j]=ij)f[i][j]=max(f[i][k]+f[k+1][j],f[i][j]);(f[i][j]=删除i到j的最大价值)

首先f[i][i]肯定是它本身 然后用(|xi — xk|×(k-i+1))求出f[i][j] 的值, (n≥j>i)

最后枚举一下就可以了

源程序:

#include<cstdio>
#include<algorithm>
using namespace std;
int ak,n,a[105],f[105][105];
int main()
{
    //freopen("remove.in","r",stdin);
    //freopen("remove.out","w",stdout);
    int o=0;
    scanf("%d",&n);
    for (int i=1;i<=n;i++)
     scanf("%d",&f[i][i]);     
    for (int i=1;i<n;i++)
     for (int j=i+1;j<=n;j++)
       f[i][j]=abs(f[j][j]-f[i][i])*(j-i+1);//初始化
    for (int i=1;i<=n;i++)
     for (int j=i;j<=n;j++)
      for (int k=i;k<j;k++)//枚举删除范围
       f[i][j]=max(f[i][k]+f[k+1][j],f[i][j]);//取最大价值
    printf("%d",f[1][n]);//愉快输出
}

转载于:https://www.cnblogs.com/Juruo-HJQ/p/9308681.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107628.html原文链接:https://javaforall.net

(0)
上一篇 2022年3月13日 下午6:35
下一篇 2022年3月13日 下午6:35


相关推荐

  • SchedulerFactoryBean[通俗易懂]

    SchedulerFactoryBean[通俗易懂]&lt;?xmlversion="1.0"encoding="UTF-8"?&gt;&lt;beans&gt;&lt;beanid="scheduler"class="org.springframework.scheduling.quartz.SchedulerFactoryBean"lazy-init="false"&gt;&lt;prope

    2022年5月10日
    52
  • 深入浅出ES6(四):模板字符串

    在上一篇文章中,我说过要写一篇风格迥异的新文章,在了解了迭代器和生成器后,是时候来品味一些不烧脑的简单知识,如果你们觉得太难了,还不快去啃犀牛书!现在,就让我们从最简单的知识学起吧!反撇号(`)基础知识ES6引入了一种新型的字符串字面量语法,我们称之为模板字符串(templatestrings)。除了使用反撇号字符`代替普通字符串的引号’或”外,它们看起来与普通

    2022年4月5日
    127
  • Vue(3)webstorm代码格式规范设置与vue模板配置

    Vue(3)webstorm代码格式规范设置与vue模板配置编译器代码格式规范设置通常我们写代码时,代码缩进都是4个空格,但是在前端中,据全球投票统计,建议使用2个空格来进行代码缩进。首先我们打开webstorm中的设置,如果使用的是mac的同学直接使用c

    2022年7月30日
    68
  • ONVIF协议–ONVIF协议简介

    ONVIF协议–ONVIF协议简介简单介绍了 ONVIF 相关的 Profile 功能

    2026年2月2日
    7
  • Sleuth如何生成traceId

    Sleuth如何生成traceIdSpringBoot 启动时在 zipkin 的包中配置 MDCScopeDeco 属性 添加 traceId 和 spanId Sleuth 版本 3 1 0 生成 traceId 和 spanId 直接使用 traceId 和 spanId 获取 日志格式为 traceId X traceId spanId X spanId Logback 天然配置 MDC 通过 LogbackMDCAd 最终填充 traceId 和 spanId 值

    2026年3月18日
    2
  • 程序化交易学习笔记(一)

    程序化交易学习笔记(一)了解学习期货程序化交易及其编程程序化交易 制定规则 严格按照规则去交易 本质 构建投资组合 程序化交易不是 科研 而是一项 工程 巴菲特说 分散化是对于无知的一种保护一 为什么要进行程序化交易减少盯盘的压力与情绪上的干扰 外盘也需要关注 超级行情时 人的情绪无法打败固定的交易模型 复制成功的交易模式其他优势 利用统计优势寻找机会点加快策略研发的速度 让交易规模达到效率化 系统化减少盲目失败

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号