【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);
}
相关推荐
wxy2024315几秒前
连年(年份)
c语言·c++·算法
LuckyRich19 分钟前
【高阶数据结构】跳表
开发语言·数据结构·c++
(lemon seed)10 分钟前
数据结构:树与二叉树(2)
数据结构·算法
ya888g12 分钟前
数据结构-图-存储-邻接矩阵-邻接表
数据结构·图论·邻接表·邻接矩阵
加勒比海涛33 分钟前
Ajax 揭秘:异步 Web 交互的艺术
前端·ajax·交互
战族狼魂42 分钟前
vue axios 如何读取项目下的json文件
javascript·vue.js·json
星河路漫漫44 分钟前
JavaScript高阶面试题:(第三天)
java·javascript·面试
桃酥40344 分钟前
贪心算法day31|56. 合并区间、738. 单调递增的数字(整数与字符串的转换)、贪心刷题总结
c++·算法·leetcode·贪心算法·字符串
van叶~1 小时前
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——12.二叉树(习题)
开发语言·c++·算法
爱吃喵的鲤鱼1 小时前
C++——深部解析哈希
c++·算法·哈希算法