本文介绍: 指定方式排序: [b, adc, ads, cds, sdadsa]添加元素后: [sdadsa, ads, b, adc, cds]打乱元素后: [sdadsa, cds, b, adc, ads]自然排序后: [adc, ads, b, cds, sdadsa]拷贝后的list1:[a, b, c, d, sdadsa]元素填充后的list2:[a, a, a, a]交换后:[sdadsa, b, c, d, a]list1的最大字符串:sdadsa。list1的最小字符串:a。
  • java.util.Collections:是个集合工具类
  • 它不是集合,而是集合的工具类

常用 API:
image.png
注意 binarySearch 方法要求元素有序

方法实现:

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


ArrayList<String>list1=new ArrayList<>();

//1.给单列集合添加元素
Collections.addAll(list1,"sdadsa","ads","b","adc","cds");
System.out.println("添加元素后: "+list1);

//2只能打乱list集合
Collections.shuffle(list1);
System.out.println("打乱元素后: "+list1);

//3.给list集合排序--按照字母大小(自然)
Collections.sort(list1);
System.out.println("自然排序后: "+list1);

//4.给list集合排序--(比较器)----
//String中默认是按照字母的abcdefg顺序进行排列的
//现在要求,按照长度排序,长度一样就按照字母大小排序
Collections.sort(list1, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
    int i = o1.length() - o2.length();
    if (i!=0){
        return i;
    }else {
        return o1.compareTo(o2);//调用自然排序即按字母大小排序
    }
}
});
System.out.println("指定方式排序: "+list1);


//5.二分法查找元素--前提是元素有序
ArrayList<String>list2=new ArrayList<>();
Collections.addAll(list2,"a","b","c","d");
int index = Collections.binarySearch(list2,"b" );//1
System.out.println("b的索引是:"+index);

//拷贝集合:如果list2长度>list1会报错
Collections.copy(list1,list2);//list2拷贝给list1
System.out.println("拷贝后的list1:"+list1);


//fill指定元素填充
Collections.fill(list2,"a");
System.out.println("元素填充后的list2:"+list2);

//获取最大值--按照自然排序的原则,即字母大小
String max = Collections.max(list1);
System.out.println("list1的最大字符串"+max);
//获取最小值--按照自然排序的原则,即字母大小
String min = Collections.min(list1);
System.out.println("list1的最小字符串"+min);


//交换指定索引的集合元素
Collections.swap(list1,0,4);// a<-->sdadsa
System.out.println(list1);

    }
}

控制台:
添加元素后: [sdadsa, ads, b, adc, cds]
打乱元素后: [sdadsa, cds, b, adc, ads]
自然排序后: [adc, ads, b, cds, sdadsa]
指定方式排序: [b, adc, ads, cds, sdadsa]
b的索引是:1
拷贝后的list1:[a, b, c, d, sdadsa]
元素填充后的list2:[a, a, a, a]
list1的最大字符串:sdadsa
list1的最小字符串:a
交换后:[sdadsa, b, c, d, a]

原文地址:https://blog.csdn.net/2301_79947226/article/details/135963648

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_63933.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注