概述
@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,按从小到大的顺序输出,并输出对应的序号所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复