数组取最大值最小值

1、数组取出最大值,最小值的方式

第一种、

遍历一边数组就可以找出需要的值,基本上可以说是速度最快的算法,还不需要排序

int [] intArray = {1,3,2,4,2,5,2,6,45,7,5,86,5,45,3,867} ;
int max = intArray[0];
int min = intArray[0];
for (int i : intArray) {
max = max>i?max:i;
min = min<i?min:i;
}
System.out.println(max+"-----"+min);//返回的最大值和最小值

第二种、

先排序,在取最大最小值

Arrays.sort(intArray.clone());//clone的目的是因为数组本身也是个对象,不想改变它本身的顺序,当然,要是顺序没什么用处,也可以不clone
System.out.println(intArray[intArray.length-1]);//最大值
System.out.println(intArray[0]);//最小值

其实在秦老师的书里,另外我自己也测试了,在1w条数据之内,这两种方法是差不多的,可以说事几乎一样的,

2、取出数组第二大值的方式、

这个就要想想了,第二大致不可以能一个,所以位置上取就不太如意了

treeSet  是可以实现删除重复的、

Integer [] intArray = {1,3,2,4,2,5,2,6,45,7,5,86,5,45,3,867} ;

List<Integer> l = Arrays.asList(intArray);
TreeSet<Integer> tl = new TreeSet<Integer>(l);
System.out.println(tl.lower(tl.last()));
//比最大值小的值



最值的计算使用集合是最简单的,使用数组是性能最好的。

---整理自:秦老师的《、、、、151个建议》


原文地址:https://www.cnblogs.com/james1207/p/3278018.html