【Leetcode 2099 】 找到和最大的长度为 K 的子序列 —— 索引与排序

给你一个整数数组 nums 和一个整数 k 。你需要找到 nums 中长度为 k子序列 ,且这个子序列的 和最大

请你返回 任意 一个长度为 k 的整数子序列。

子序列 定义为从一个数组里删除一些元素后,不改变剩下元素的顺序得到的数组。

示例 1:

复制代码
输入:nums = [2,1,3,3], k = 2
输出:[3,3]
解释:
子序列有最大和:3 + 3 = 6 。

示例 2:

复制代码
输入:nums = [-1,-2,3,4], k = 3
输出:[-1,3,4]
解释:
子序列有最大和:-1 + 3 + 4 = 6 。

示例 3:

复制代码
输入:nums = [3,4,3,3], k = 2
输出:[3,4]
解释:
子序列有最大和:3 + 4 = 7 。
另一个可行的子序列为 [4, 3] 。

索引与排序

TypeScript 复制代码
//索引与排序
function maxSubsequence(nums: number[], k: number): number[] {
  // 将索引保存
  let falseMap = nums.map((v, i) => [v, i]);
  // 从大到小排序
  falseMap.sort(([a], [b]) => b - a);
  falseMap = falseMap.slice(0, k);
  //按索引从小到大排序
  falseMap.sort((a, b) => a[1] - b[1]);
  //生成值,去掉索引
  return falseMap.map(([v]) => v);
}
相关推荐
Ryan今天学习了吗3 分钟前
💥不说废话,带你上手使用 qiankun 微前端并深入理解原理!
前端·javascript·架构
高端章鱼哥4 分钟前
前端新人最怕的“居中问题”,八种CSS实现居中的方法一次搞懂!
前端
冷亿!6 分钟前
Html爱心代码动态(可修改内容+带源码)
前端·html
Predestination王瀞潞10 分钟前
Java EE开发技术(第六章:EL表达式)
前端·javascript·java-ee
掘金0118 分钟前
在 Vue 3 项目中使用 MQTT 获取数据
前端·javascript·vue.js
QuantumLeap丶18 分钟前
《uni-app跨平台开发完全指南》- 03 - Vue.js基础入门
前端·vue.js·uni-app
一 乐33 分钟前
个人理财系统|基于java+小程序+APP的个人理财系统设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·后端·小程序
wyzqhhhh42 分钟前
同时打开两个浏览器页面,关闭 A 页面的时候,要求 B 页面同时关闭,怎么实现?
前端·javascript·react.js
晴殇i42 分钟前
从 WebSocket 到 SSE:实时通信的轻量化演进
前端·javascript
网络点点滴44 分钟前
reactive创建对象类型的响应式数据
前端·javascript·vue.js