#Arrays类的方法都是static修饰的静态方法,在使用时可以直接使用类名进行调用,而不用使用对象来调用,不用不是不能调用
package se.he.array; import java.util.Arrays; public class ArrayDome06 { public static void main(String[] args) { int[] a = {1,45,45,50,5115,1,158}; int[] b = {5,44,20,540,51105,10,1058}; int[] c = {1,45,45,50,5115,1,158}; int[] d = {1,2,3,7,8,10}; //binarySearch:搜索数组 /*注意 要搜索的数组里的元素值必须经过排序,否则会导致搜索结果false 搜索的目标值在数组中存在就会打印目标值所在的元素下标 不在的话就会先打印- 再+第一个大于目标值的元素下标+1 -6 3 -4,目标值在不在目标数组中就很容易区分了 */ int d1 = Arrays.binarySearch(d,3);//d是要搜索的数组,key是要搜索的值 int d2 = Arrays.binarySearch(d,9);//元素下标5比目标值9大,所以打印下标5+1=6 int d3 = Arrays.binarySearch(d,7); int d4 = Arrays.binarySearch(d,4); System.out.println(d1+" "+d2+" "+d3+" "+d4+" "); //binarySearch:区间搜索数组 int dd = Arrays.binarySearch(d,3);//打印下标2 int dd1 = Arrays.binarySearch(d,0,1,3);//都比目标值小打印-2 int dd2 = Arrays.binarySearch(d,3,5,3);//都比目标值大打印-4 /*加了两个int变量,代表区间的开始和结束 从fromindex(包含)到toindex(不包含)这个区间里面搜索 打印结果和搜索数组原理一样 当如果区内的值都比目标值小,则打印- 再+toindex+1 如果区间内的值都比目标值大,则打印- 再+fromlndex+1 */ System.out.println(dd); System.out.println(dd1); System.out.println(dd2); //比较数组中元素值是否相等,打印结果只能是布尔值类型 boolean aa = Arrays.equals(a,b); boolean bb = Arrays.equals(b,c); boolean cc = Arrays.equals(a,c); System.out.println(aa); System.out.println(bb); System.out.println(cc); System.out.println(a);//[I@14ae5a5对象 //打印数组元素:toString System.out.println(Arrays.toString(a)); //自己写打印元素的方法也可,但是避免重复造轮子 printA(a); //数组进行升序排序:sort Arrays.sort(a); System.out.println(Arrays.toString(a)); //给每个数组元素进行填充赋值、也可以给区间元素填充,比如2到5之间的下标34填充赋值 //a:数组,val:赋值 Arrays.fill(a,0); System.out.println(Arrays.toString(a)); } public static void printA(int[]a) { for (int i = 0; i < a.length; i++) { if (i==0){ System.out.print("["); } if (i==a.length-1){ System.out.print(a[i]+"]"); }else { System.out.print(a[i]+", "); } } } }