查找
1、二分查找
1 package package1_Array; 2 /** 3 * 二分查找 4 * 前提:有序数组 5 * 时间复杂度:O(log(n)) 6 */ 7 public class array_exe8 { 8 public static void main(String[] args) { 9 int[] arr = new int[]{-99,-54,-2,0,2,33,43,256,999};////arr必须有序 10 System.out.println(BinarySearch(arr,-2)); 11 12 } 13 public static int BinarySearch(int[] arr,int num){//在有序数组中查找num的索引 14 boolean Flag = false; 15 int low = 0,high = arr.length-1; 16 while(low <= high){ 17 int mid = (high + low)/2; 18 if(arr[mid] < num){ 19 low = mid+1; 20 }else if(arr[mid] > num){ 21 high = mid-1; 22 }else{ 23 return mid; 24 } 25 } 26 return -1;//找不到指定的元素则返回-1 27 } 28 }
排序
基本概念
稳定与不稳定;内部排序(待排序的序列完全放在内存中进行排序)和外部排序(排序过程需访问外存);
排序算法的选择
- 若n较小(如n≤50),可采用 直接插入或 直接选择排序。
- 当记录规模较小时,直接插入排序较好;否则因为直接选择移动的记录数少于直接插入,应选直接选择排序为宜。
- 若文件初始状态基本有序(指正序),则应选用 直接插 入、 冒泡或随机的 快速排序为宜;
- 若n较大,则应采用时间复杂度为O(nlgn)的排序方法: 快速排序、 堆排序或归并排序。
1、快速排序
1 package package1_Array.array_Sort; 2 import java.util.Arrays; 3 4 //快速排序 5 //思想:分而治之 6 //假设我们现在需要对数组做增序排序 7 public class QuickSort { 8 public static void main(String[] args) { 9 int arr[]=new int[]{3,1,-9,12,54,78,0,100,-10}; 10 QS(arr,0,arr.length-1); 11 System.out.println(Arrays.toString(arr));//[-10, -9, 0, 1, 3, 12, 54, 78, 100] 12 } 13 14 public static void QS(int[] arr,int s,int t){ 15 if(s<t){//类似树的前序遍历 16 int i=Partition(arr,s,t); 17 QS(arr,s,i-1); 18 QS(arr,i+1,t); 19 } 20 } 21 22 public static int Partition(int arr[],int low,int high){ 23 int temp = arr[low];//每次选择下标为low的元素作为划分的基准 24 while(low < high){ 25 while(low < high && arr[high] > temp){//先移动high,从右往左找比temp小的数组元素的下标 26 high--; 27 } 28 if(low < high){ 29 arr[low] = arr[high];//如果没有越界,则做填充,换low移动 30 low++; 31 } 32 while(low < high && arr[low] < temp){//移动low,从左往右找比temp大的数组元素的下标 33 low++; 34 } 35 if(low < high){//如果没有越界,则做填充,换high移动 36 arr[high] = arr[low]; 37 high--; 38 } 39 } 40 arr[low] = temp;//把temp填充到此次划分的位置 41 return low;//返回划分的位置下标 42 } 43 }
2、堆排序(不稳定)
java中内置了堆排序,使用优先队列实现的。
平均时间复杂度:O(n*log(n))
1 package daily_code; 2 3 import org.junit.Test; 4 import java.util.PriorityQueue; 5 //import java.util.Set; 6 7 public class heapTest { 8 //测试java中定义的堆结构-默认是建立小顶堆 9 @Test 10 public void testHeap1(){ 11 int[] arr = new int[]{4,5,1,6,2,7,3,8}; 12 PriorityQueue<Integer> heap = new PriorityQueue(); 13 for(int item: arr) { 14 heap.add(item); 15 } 16 17 while(! heap.isEmpty()){ 18 System.out.print(heap.poll()); 19 }//12345678 20 } 21 22 //测试java中定义的堆结构-使用PriorityQueue实现大顶堆 23 @Test 24 public void testHeap2(){ 25 //方式1 26 // PriorityQueue<Integer> maxHeap = new PriorityQueue<>(new Comparator(){ 27 // public int compare(Object o1,Object o2){ 28 // return (int)o2 - (int)o1; 29 // } 30 // }); 31 32 PriorityQueue<Integer> maxHeap = new PriorityQueue<>((o1,o2) -> (o2-o1));//方式2 33 34 int[] arr = new int[]{4,5,1,6,2,7,3,8}; 35 for(int item: arr) { 36 maxHeap.add(item); 37 } 38 39 while(! maxHeap.isEmpty()){ 40 System.out.print(maxHeap.poll());//87654321 41 } 42 } 43 }
数组工具类的常见用法
1 package package1_Array; 2 3 import java.util.Arrays; 4 5 public class array_tools { 6 public static void main(String[] args) { 7 //1.boolean equals(int[] a,int[] b) 判断两个数组是否相等 8 int[] arr1 = new int[]{1,2,3,4}; 9 int[] arr2 = new int[]{1,4,2,3}; 10 int[] arr3 = new int[]{1,2,3,4}; 11 int[] arr4 = arr1; 12 System.out.println(Arrays.equals(arr1,arr2));//false 13 System.out.println(Arrays.equals(arr1,arr3));//true 14 System.out.println(Arrays.equals(arr1,arr4));//true 15 16 //2.String toString(int[] a) 输出数组信息。 17 System.out.println(Arrays.toString(arr1));//[1, 2, 3, 4] 18 19 //3.void fill(int[] a,int val) 将指定值填充到数组之中 20 Arrays.fill(arr1,1); 21 System.out.println(Arrays.toString(arr1));//[1, 1, 1, 1] 22 23 //4.void sort(int[] a) 对数组进行排序 24 Arrays.sort(arr2); 25 System.out.println(Arrays.toString(arr2));//[1, 2, 3, 4] 26 27 //5.int binarySearch(int[] a,int key) 对排序后的数组进行二分法检索指定的值。 28 int[] arr5 = new int[]{5,900,1,0,77,30,64,700}; 29 Arrays.sort(arr5); 30 System.out.println(Arrays.toString(arr5));//[0, 1, 5, 30, 64, 77, 700, 900] 31 int index = Arrays.binarySearch(arr5,64); 32 System.out.println(index);//4 33 } 34 }