本文介绍: 指定方式排序: [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:
注意 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进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。