当前位置: 首页 > article >正文

LeetCode 每日一题 最佳观光组合

最佳观光组合

给你一个正整数数组 values,其中 values[i] 表示第 i 个观光景点的评分,并且两个景点 i 和 j 之间的 距离 为 j - i。
一对景点(i < j)组成的观光组合的得分为 values[i] + values[j] + i - j ,也就是景点的评分之和 减去 它们两者之间的距离。
返回一对观光景点能取得的最高分。
示例 1:
输入:values = [8,1,5,2,6]
输出:11
解释:i = 0, j = 2, values[i] + values[j] + i - j = 8 + 5 + 0 - 2 = 11
示例 2:
输入:values = [1,2]
输出:2
提示:
2 <= values.length <= 5 * 104
1 <= values[i] <= 1000

题解

这道题需要我们计算 values[i] + values[j] + i - j

关键是我们将 values[i] + i 与 values[j] -j 看成一起的

这样的话,values[i] + i 就是一个定值,我们在枚举 j 的时候,同时维护 values[i] + i 的最大值

我们就找到 values[i] + i 的最大值与 values[j] - j 的和的最大值就是需要的答案

最开始我的错误思路:
我是记录values[i] +i 的最大值与 values[j] +j 的最大值然后相加返回
错误点是:当两个的最大值同时取到的时候,不一定满足 i<j 这个条件

代码如下↓

int maxScoreSightseeingPair(int* values, int valuesSize) {
    int res=0;
    int m1=0,m2=0;
    for(int i=0,j=1;j<valuesSize;j++,i++)
    {
        if(values[i]+i>m1)
        {
            m1=values[i]+i;
        }
        m2=values[j]-j;
        if(m1+m2>res)
        {
            res=m1+m2;
            printf("%d %d\n",m1,m2);
        }
    }
    return res;
}

http://www.kler.cn/a/326663.html

相关文章:

  • InstructIR: High-Quality Image Restoration Following Human Instructions 论文阅读笔记
  • Logstash 安装与部署(无坑版)
  • python基础学习笔记
  • koa项目实战 == 实现注册登录鉴权
  • 探索Python编程:从入门到实践的全面指南
  • C语言教程——操作符详解(2)
  • 水波荡漾效果+渲染顺序+简单UI绘制
  • Chromium 屏蔽“缺少 Google API 密钥,因此 Chromium 的部分功能将无法使用。”提示 c++
  • Conda 虚拟环境使用指南,python,anaconda,miniconda
  • MySQL InnoDB 事务commit逻辑分析
  • C++的new关键字
  • 如何在Android上运行Llama 3.2
  • 关于TrustedInstaller权限
  • c++-类和对象-设计立方体类
  • 每天学习一个技术栈 ——【Django Channels】篇(2)
  • ansible实现远程创建用户
  • [BUUCTF从零单排] Web方向 03.Web入门篇之sql注入-1(手工注入详解)
  • Java 编码系列:注解处理器详解与面试题解析
  • Uptime Kuma运维监控服务本地部署结合内网穿透实现远程在线监控
  • PostgreSQL的扩展Citus介绍
  • 非常全面的中考总复习资料-快速提升中考成绩!
  • 总结C/C++中内存区域划分
  • 点餐小程序实战教程14点餐功能
  • 心理咨询行业为何要有自己的知识付费小程序平台 心理咨询小程序搭建 集师saas知识付费小程序平台搭建
  • 遇到 Docker 镜像拉取失败的问题时该如何解决
  • 六、设计模式-6.3、责任链模式