如何在Java中根据另一个配对集合对一个集合进行排序

假如我有两个有序集合(插入顺序很重要,而且我需要忽略重复项LinkedHashSet),其中一个集合中的第 n 个元素与另一个集合中的第 n 个元素配对。但它们不是成对添加的,而是最终结果会是成对的。

例如,在下面的代码中5,会与 配对1.1f,3也会与 配对0.5f

java 复制代码
LinkedHashSet<Integer> slotIDs = new LinkedHashSet<>();
            LinkedHashSet<Float> pitches = new LinkedHashSet<>();

            // 模拟数据添加过程
            slotIDs.add(3);
            slotIDs.add(1);
            slotIDs.add(2);
            pitches.add(0.5f);
            pitches.add(2.2f);
            slotIDs.add(5);
            slotIDs.add(2); 
            pitches.add(1.3f);
            slotIDs.add(4);
            pitches.add(1.1f);
            pitches.add(1.3f);
            pitches.add(0.7f);
            slotIDs.add(5);
            pitches.add(1.1f);

我想根据slotIDs配对结果pitches从低到高排序。在上面的例子中,我想要这样的结果:[3, 4, 5, 2, 1]

java 复制代码
					// 1. 将Set转换为List,以便通过索引访问
            List<Integer> slotIDList = new ArrayList<>(slotIDs);
            List<Float> pitchList = new ArrayList<>(pitches);

            // 2. 确定有效配对的数量(以较短的列表为准)
            int pairCount = Math.min(slotIDList.size(), pitchList.size());

            // 3. 创建一个包含索引的列表 [0, 1, 2, ...],并根据对应的pitch值进行排序
            List<Integer> sortedIndices = IntStream.range(0, pairCount)
                    .boxed()
                    .sorted(Comparator.comparing(pitchList::get))
                    .collect(Collectors.toList());

            // 4. 根据排序后的索引,构建最终的slotID列表
            List<Integer> result = sortedIndices.stream()
                    .map(slotIDList::get)
                    .collect(Collectors.toList());

            // --- 核心逻辑结束 ---

            System.out.println(result); // 输出:

结果

相关推荐
云烟成雨TD2 小时前
Spring AI Alibaba 1.x 系列【28】Nacos Skill 管理中心功能说明
java·人工智能·spring
升鲜宝供应链及收银系统源代码服务2 小时前
OMS 订单模块重构正式文档(一)---升鲜宝生鲜配送供应链管理系统
java·开发语言·重构·生鲜配送源代码·生鲜供应链源代码
Han.miracle2 小时前
Redis 全套笔记:基础 API + 三大架构 + 缓存三大问题
java·windows·redis
zzb15802 小时前
Fragment 生命周期深度图解:从 onAttach 到 onDetach 完整流程(面试必备)
android·java·面试·安卓
银色火焰战车2 小时前
浅析golang中的垃圾回收机制(GC)
java·jvm·golang
zhangjw342 小时前
第4篇:Java数组与字符串:从基础用法到面试高频考点
java·java基础知识
俺爱吃萝卜2 小时前
Spring Boot 3 + JDK 17:新一代微服务架构最佳实践
java·spring boot·架构
曹牧3 小时前
Spring :component-scan
java·后端·spring
qq_12084093713 小时前
Three.js 工程向:GLTFLoader 管线、Draco/KTX2 与资源管理
开发语言·javascript·ecmascript