顺丰面试提到的一个算法题

顺丰面试提到的一个算法题

面试过程中大脑空白,睡了一觉后突然想明白了

原理非常简单就是根据数组中元素的值对值对应的索引进行排序

哎,,,,具体看以下代码吧[使用 Java 17 中 Stream 实现]

最好别用 CSDN 提供的在线运行验证代码,我建议你还是将代码拷贝到本地目标环境下运行

java 复制代码
import java.util.AbstractMap;
import java.util.stream.IntStream;

public class Main {

    // 获取数组中第k大的元素及其索引
    public static void main(String[] args) {

        // 定义变量k,用于后续操作中指定获取的元素数量
        int k = 5;

        // 初始化一个整数数组nums,包含一组待处理的数字
        int[] nums = {12, 11, 9, 15, 10};

        // 使用IntStream.range生成一个包含数组索引的流
        // .range(0, nums.length) 生成一个从0到数组长度的索引流
        // .boxed() 将int值包装为Integer对象,以便进行后续的排序操作
        // .sorted((i1, i2) -> Integer.compare(nums[i2], nums[i1])) 根据数组nums中的值对索引进行降序排序
        // .limit(k) 限制流的大小为k,即只取数组中最大的k个元素
        // .skip(k - 1L) 跳过前k-1个元素,留下第k个最大的元素
        // .map(i -> new AbstractMap.SimpleEntry<>(i, nums[i])) 将索引i映射为一个键值对(i, nums[i]),便于后续处理
        // .findFirst() 查找流中的第一个元素,即第k个最大的元素
        // .ifPresent(...) 如果找到了元素,则执行给定的消费函数,输出数组索引及其对应的值
        IntStream.range(0, nums.length)
                .boxed()
                .sorted((i1, i2) -> Integer.compare(nums[i2], nums[i1]))
                .limit(k)
                .skip(k - 1L)
                .map(i -> new AbstractMap.SimpleEntry<>(i, nums[i]))
                .findFirst()
                .ifPresent(entry ->
                        System.out.println("数组索引: " + entry.getKey() + " --> 数组索引对应的值: " + entry.getValue())
                );

    }

}
相关推荐
零售ERP菜鸟26 分钟前
范式革命:从“信息化”到“数字化”的本质跃迁
大数据·人工智能·职场和发展·创业创新·学习方法·业界资讯
power 雀儿41 分钟前
掩码(Mask)机制 结合 多头自注意力函数
算法
发现一只大呆瓜42 分钟前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
会叫的恐龙1 小时前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
小糯米6011 小时前
C++顺序表和vector
开发语言·c++·算法
We་ct1 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
Lionel6891 小时前
分步实现 Flutter 鸿蒙轮播图核心功能(搜索框 + 指示灯)
算法·图搜索算法
小妖6661 小时前
js 实现快速排序算法
数据结构·算法·排序算法
xsyaaaan1 小时前
代码随想录Day30动态规划:背包问题二维_背包问题一维_416分割等和子集
算法·动态规划
千寻girling2 小时前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试