栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java Rarrange枚举数组

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java Rarrange枚举数组

由于是

enum
Implements
Comparable
,您可以简单地对数组进行排序然后反转:

public static void reorder(Animal[] animals) {    Arrays.sort(animals);    for (int i = 0, j = animals.length - 1; i < j; ++i, --j) {        Animal tmp = animals[i];        animals[i] = animals[j];        animals[j] = tmp;    }}

您也许还可以做到以下几点:

List<Animal> list = Arrays.asList(animals);Collections.sort(list);Collections.reverse(list);

这与API调用基本上具有相同的作用,只是将数组包装在

List
对象中的开销非常小。您甚至可以这样做:

Arrays.sort(animals, Collections.reverseOrder());

(感谢Bhesh Gurung提出的建议。)

编辑:如果您必须正好处理两个值,则可以通过简单地从两端进行扫描,在发现两个元素乱序时进行交换来做得更好:

public static void reorder(Animal[] animals) {    int first = 0;    int last = animals.length - 1;    while (first < last) {                while (animals[first].ordinal() == 1 && first < last) { ++first;        }        while (animals[last].ordinal() == 0 && first < last) { --last;        }        if (first < last) {  Animal temp = animals[first]; animals[first] = animals[last]; animals[last] = temp; ++first; --last;        }    }}

但是,如果您需要做的只是生成正确的输出(而不是对数组进行实际排序),那么@ajb在注释中建议的方法是最好的:只需计算有多少只绵羊和山羊,然后打印相应的值即可很多次。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/455237.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号