java - topN排序问题求解。
问题描述
有个字符串数组,string[] str = {A,B,C,D,E,F,G,H};,数组分别对应一个整数数组,int[] a = {3,2,6,4,8,9,1,23};,类似于这样,对整数数组中的数从大到小排序,然后将整数数组对应的字符串数组按序输出,求解java代码的实现方式。
问题解答
回答1:你定义一个 Holder 类,用来保存 字符-数字 这个映射,然后对所有的 Holder,按照 Holder 中的数字从大到小排序,最后按序输出每个 Holder 的字符。
import java.util.Arrays;public class Test { static class Holder implements Comparable<Holder> {public int num;public String str;public Holder(String str, int num) { this.str = str; this.num = num;}@Overridepublic int compareTo(Holder that) { return that.num - this.num; // 逆序排序} } public static void test(String[] strs, int[] nums) {if (strs.length != nums.length) { return;}Holder[] holders = new Holder[strs.length];for (int i = 0; i < strs.length; i++) { holders[i] = new Holder(strs[i], nums[i]);}Arrays.sort(holders);for (Holder holder : holders) { System.out.print(holder.str + ' ');}System.out.println(); } public static void main(String[] args) throws Exception {String[] strs = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H'};int[] a = {3, 2, 6, 4, 8, 9, 1, 23};test(strs, a); }}
运行结果:
相关文章:
1. vue计算属性怎么样与for结合使用2. angular.js - vue/react 渲染内容抖动3. html5 - 如何实现图中的刻度渐变效果?4. redis - 不知道国内有多少用Python + CouchDB的朋友,谈一下经验。。。5. javascript - vue v-for循环,子循环内要取到父循环的键值,如何做到?6. javascript - Object.create(null) 和 {} 区别是什么7. PHP能实现百度网盘的自动化么?8. android百度地图定位问题9. node.js - version3的generic-pool问题10. python - 如何把152753这个字符串转变成时间格式15:27:53
