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

力扣(leetcode)每日一题 1014 最佳观光组合

题干

1014. 最佳观光组合

给你一个正整数数组 values,其中 values[i] 表示第 i 个观光景点的评分,并且两个景点 ij 之间的 距离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
解法

两个点,一个start,一个end,start点的位置小于end。
可以得出start点的价值就是 values[i] + i 景点价值加上本身位置价值。
end点的价值就是 values[j] - j 景点价值减去本身位置价值
这样只要把两个列表的值相加得到最大就可以了 公式如下 Max( startArr[i] + endArr[j]) j>i求最大值可以预先生成

for (int i = length - 2; i >= 0; i--) {  endArr[i] = Math.max(endArr[i], endArr[i + 1]);
}  

这样可以将复杂度从LogN^N降低到logN


public static int maxScoreSightseeingPair(int[] values) {  int length = values.length;  int[] startArr = new int[length];  int[] endArr = new int[length];  for (int i = 0; i < length; i++) {  startArr[i] = values[i] + i;  endArr[i] = values[i] - i;  }  // start i + end j  //    // 确定了i  需要找end这边的最大值  for (int i = length - 2; i >= 0; i--) {  endArr[i] = Math.max(endArr[i], endArr[i + 1]);  }  int max = Integer.MIN_VALUE;  for (int i = 0; i < length - 1; i++) {  int value = startArr[i] + endArr[i + 1];  max = Math.max(max, value);  }  return max;  
}  

优化一下写法
节省一个数组空间,节省一次遍历,然后变量写的抽象些

  
public static int maxScoreSightseeingPair(int[] values) {  int[] endArr = new int[values.length];  for (int i = values.length - 1; i >= 0; i--) {  if (i == values.length - 1) {  endArr[i] = values[i] - i;  } else {  endArr[i] = Math.max(values[i] - i, endArr[i + 1]);  }  }  int max = Integer.MIN_VALUE;  for (int i = 0; i < values.length - 1; i++) {  max = Math.max(max, values[i] + i + endArr[i + 1]);  }  return max;  
}

在这里插入图片描述
优化后
在这里插入图片描述

空间上还可以进一步优化。从后往前遍历,用新的值覆盖旧的值来达到节约内存的目的


public static int maxScoreSightseeingPair(int[] values) {  int max = Integer.MIN_VALUE;  int maxright = values[values.length - 1] - (values.length - 1);  for (int i = values.length - 2; i >= 0; i--) {  max = Math.max(max, values[i] + i + maxright);  maxright = Math.max(values[i] - i, maxright);  }  return max;  
}

再优化一个空间值


public static int maxScoreSightseeingPair(int[] values) {  int max = Integer.MIN_VALUE;  values[values.length - 1] = values[values.length - 1] - (values.length - 1);  for (int i = values.length - 2; i >= 0; i--) {  max = Math.max(max, values[i] + i + values[i + 1]);  values[i] = Math.max(values[i] - i, values[i + 1]);  }  return max;  
}

没啥用放弃研究了,在研究也感觉意义不大
在这里插入图片描述

总结

对找下标i右边的最大值进行预先处理,达到复用。也算是记忆搜索的一种。属于简单题目。

相关文章:

  • React第十章(useState)
  • windows上安装mingw教程及mingw64国内下载地址汇总
  • 【JavaEE】http/https 超级详解
  • 六,MyBatis-Plus 扩展功能(逻辑删除,通用枚举,字段类型处理,自动填充功能,防全表更新与删除插件,MybatisX快速开发插件)
  • css的盒模型
  • 数据集-目标检测系列-豹子 猎豹 检测数据集 leopard>> DataBall
  • Spring Boot框架下的足球青训俱乐部后台开发
  • 数据分析-28-交互式数据分析EDA工具和低代码数据科学工具
  • C++ STL(1)迭代器
  • 速刷DuckDB官网24小时-掌握核心功法
  • 基于Hive和Hadoop的电商消费分析系统
  • 新农人的求索:既要种菜,也要种钱
  • web开发(1)-基础
  • 2024年7月大众点评乌鲁木齐美食店铺基础信息
  • FFmpeg源码:avio_skip函数分析
  • 【108天】Java——《Head First Java》笔记(第1-4章)
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • android图片蒙层
  • C++类的相互关联
  • docker python 配置
  • Hibernate最全面试题
  • javascript数组去重/查找/插入/删除
  • js正则,这点儿就够用了
  • js中forEach回调同异步问题
  • Logstash 参考指南(目录)
  • php ci框架整合银盛支付
  • PyCharm搭建GO开发环境(GO语言学习第1课)
  • vue-cli在webpack的配置文件探究
  • 翻译--Thinking in React
  • 开源SQL-on-Hadoop系统一览
  • 利用阿里云 OSS 搭建私有 Docker 仓库
  • 前端知识点整理(待续)
  • 思维导图—你不知道的JavaScript中卷
  • 腾讯优测优分享 | Android碎片化问题小结——关于闪光灯的那些事儿
  • 译有关态射的一切
  • 与 ConTeXt MkIV 官方文档的接驳
  • FaaS 的简单实践
  • ​​​​​​​开发面试“八股文”:助力还是阻力?
  • ​Python 3 新特性:类型注解
  • ​VRRP 虚拟路由冗余协议(华为)
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • #我与Java虚拟机的故事#连载10: 如何在阿里、腾讯、百度、及字节跳动等公司面试中脱颖而出...
  • (搬运以学习)flask 上下文的实现
  • (分布式缓存)Redis分片集群
  • (附源码)ssm考试题库管理系统 毕业设计 069043
  • (学习日记)2024.02.29:UCOSIII第二节
  • (转)mysql使用Navicat 导出和导入数据库
  • .NET Core WebAPI中使用swagger版本控制,添加注释
  • .NET HttpWebRequest、WebClient、HttpClient
  • .NET 表达式计算:Expression Evaluator
  • .Net 高效开发之不可错过的实用工具
  • .netcore 获取appsettings
  • .net开源工作流引擎ccflow表单数据返回值Pop分组模式和表格模式对比
  • .net项目IIS、VS 附加进程调试
  • .NET性能优化(文摘)