数组集合问题

枫叶落林 2018-10-13 04:23:28
数组和集合获取最大值,效率最高要怎么写?(类型都是integer)
...全文
381 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
mmmmm12342 2018-10-17
  • 打赏
  • 举报
回复
引用 8 楼 孟1234的回复:
数组添加完先排序 Array.short[int[] arr], 然后最大值就是 arr[arr.length-1];
集合用HashSet直接添加就自动排序了 然后获取最后一个元素就可以了,如果有重复的加一个comparator就行略
用TreeSet,HashSet或List也可以,需要加比较器
mmmmm12342 2018-10-17
  • 打赏
  • 举报
回复
数组添加完先排序 Array.short[int[] arr], 然后最大值就是 arr[arr.length-1];
集合用HashSet直接添加就自动排序了 然后获取最后一个元素就可以了,如果有重复的加一个comparator就行略
十八道胡同 2018-10-16
  • 打赏
  • 举报
回复
package com.demo;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class Test02 {
public static void main(String[] args) {

List<Integer> list=new ArrayList<Integer>();
for (int i = 0; i < 10000; i++) {
list.add((int)(Math.random()*1000));
System.out.println(list.get(i));
}
System.out.println("======");
System.out.println(Collections.max(list));

Integer[] ArrList=new Integer[10000];
for (int i = 0; i < 10000; i++) {
ArrList[i]=(int)(Math.random()*1000);
System.out.println(ArrList[i]);
}
System.out.println("======");
System.out.println(Collections.max(Arrays.asList(ArrList)));
}
}
枫叶落林 2018-10-16
  • 打赏
  • 举报
回复
楼上请问数组的怎么使用
引用 3 楼 LCL_data 的回复:
package com.demo;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class Test02 {
    public static void main(String[] args) {

        List<Integer> list=new ArrayList<Integer>();
        for (int i = 0; i < 10000; i++) {
            list.add((int)(Math.random()*1000));
            System.out.println(list.get(i));
        }
        System.out.println("======");
        System.out.println(Collections.max(list));
    }
}
看时间复杂度,排序肯定没有Collections.max快。

 public static <T extends Object & Comparable<? super T>> T max(Collection<? extends T> coll) {
        Iterator<? extends T> i = coll.iterator();
        T candidate = i.next();

        while (i.hasNext()) {
            T next = i.next();
            if (next.compareTo(candidate) > 0)
                candidate = next;
        }
        return candidate;
    }
枫叶落林 2018-10-16
  • 打赏
  • 举报
回复
其实数组的没有这么复杂,直接用IntStream.of(a).max().getAsInt();(a为数组,类型为Integer)
kingmax54212008 2018-10-16
  • 打赏
  • 举报
回复
用数组等于自己写算法。

用集合算法等于已经封装了。
十八道胡同 2018-10-14
  • 打赏
  • 举报
回复
package com.demo;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class Test02 {
public static void main(String[] args) {

List<Integer> list=new ArrayList<Integer>();
for (int i = 0; i < 10000; i++) {
list.add((int)(Math.random()*1000));
System.out.println(list.get(i));
}
System.out.println("======");
System.out.println(Collections.max(list));
}
}


看时间复杂度,排序肯定没有Collections.max快。


public static <T extends Object & Comparable<? super T>> T max(Collection<? extends T> coll) {
Iterator<? extends T> i = coll.iterator();
T candidate = i.next();

while (i.hasNext()) {
T next = i.next();
if (next.compareTo(candidate) > 0)
candidate = next;
}
return candidate;
}

冲上云霄 、 2018-10-13
  • 打赏
  • 举报
回复
数组直接用arrays类排序,排序后取最大值,集合用collections排序,排序后取最大值
xiaomifeng1010 2018-10-13
  • 打赏
  • 举报
回复
排个序,取最后一个元素

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧