我是靠谱客的博主 成就路灯,最近开发中收集的这篇文章主要介绍用程序给出随便大小的10个数字,序号为1-10,按从小到大的顺序输出,并输出对应的序号,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

@Test
public void test9() {
Random random = new Random();
HashMap<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < 10; i++) {
map.put(i + 1, random.nextInt(1000));
}
for (Entry<Integer, Integer> m : map.entrySet()) {
System.out.println(m.getKey() + “----” + m.getValue());
}
System.out.println("-----排序后-----");
map=(HashMap<Integer, Integer>) sortMap(map);
for (Entry<Integer, Integer> m : map.entrySet()) {
System.out.println(m.getKey() + “----” + m.getValue());
}
}
/**
*
* @param map 要进行排序的map
* @return 返回排序后的map
/
public static Map<Integer, Integer> sortMap(Map<Integer, Integer> map){
ArrayList<Entry<Integer,Integer>> list = new ArrayList<>(map.entrySet());
Collections.sort(list,new Comparator(){
@Override
public int compare(Object o1, Object o2) {
return ((Comparable) ((Map.Entry) (o1)).getValue())
.compareTo(((Map.Entry) (o2)).getValue());
}
});
//应该用linkedmap hashmap取出的顺序和放入的顺序不一致
Map<Integer, Integer> sortedMap = new LinkedHashMap<Integer, Integer>();
for (Entry<Integer, Integer> entry : list) {
sortedMap.put(entry.getKey(), entry.getValue());
}
return sortedMap;
}
/

运行结果
1----684
2----289
3----178
4----870
5----711
6----772
7----276
8----612
9----327
10----2
-----排序后-----
10----2
3----178
7----276
2----289
9----327
8----612
1----684
5----711
6----772
4----870
*/

最后

以上就是成就路灯为你收集整理的用程序给出随便大小的10个数字,序号为1-10,按从小到大的顺序输出,并输出对应的序号的全部内容,希望文章能够帮你解决用程序给出随便大小的10个数字,序号为1-10,按从小到大的顺序输出,并输出对应的序号所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部