九、設計模式以及查找、排序算法

九、設計模式

單例模式的幾種實現方法

懶漢模式、餓漢模式、雙重檢查加鎖
【1】懶漢模式:
延遲加載,在使用時纔去初始化;
在這裏插入圖片描述
【2】餓漢模式:
在這裏插入圖片描述
【3】雙重檢查加鎖:
在這裏插入圖片描述

1. 說一下你熟悉的設計模式?

分爲四類:
創建模式:單例模式、工程模式;
結構模式:代理模式;
行爲模式:觀察者模式、迭代器模式;
線程池模式。
在這裏插入圖片描述

2. 簡單工廠和查詢工廠有什麼區別?

在這裏插入圖片描述

3. 常用的數組排序算法、查找算法?

常用的數組排序算法:冒泡排序、選擇排序、插入排序;
常用的數組查找算法:線性查找法、二分法查找法(即折半查找):針對有序數組,需要先排好序再使用:eg:

public static int binarySearch(int[] arr,int number){
	int start=0;//數組下標從0開始
	int end=arr.length-1;//數組最大下標數爲數組長度-1
	while(start<=end){
		int middle=(start+end)/2;
		if (number==arr[middle]) {
			return middle;
		}else if(number<arr[middle]){
			end=middle-1
		}else{
			start=middle+1;
		}
	}
	return -1;
}

3_1. 排序有哪幾種方法,用 Java實現一個快排?

有:冒泡排序、選擇排序、插入排序、歸併排序、分配排序、快速排序;

【1_ 冒泡排序 】: 兩兩比較,大的下沉(從下往上排序,上面是 j,下面是 j+1);

int[] arr={1,7,6,3};
for (int i=0;i<arr.length-1;i++) {
    for (int j=0;j<arr.length-i-1;j++) {
        if (arr[j]>arr[j+1]) {
            int temp=arr[j+1];
            arr[j+1]=arr[j];
            arr[j]=temp;
        }
    }   
}

【2_ 選擇排序】: 每一輪找到最小值從上往下排序;

int[] arr={1,7,6,3};
for (int i=0;i<arr.length;i++) {
    int min=i;
    for (int j=i+1;j<arr.length;j++ ) {
        if (arr[j]<arr[min]) {
            min=j;
        }
    }
    if (i!=min) {//若找到的最小值位置不在固定的i位置上,
        int temp=arr[i];//將其放到要排序的位置i上
        arr[i]=arr[min];
        arr[min]=temp;
    }
}

【3_ 插入排序】:

int[] arr={1,7,6,3};
for (int i=1;i<arr.length;i++) {
    int temp=arr[i];
    int j=i;
    while(j>0&&temp<arr[j-1]){
        arr[j]=arr[j-1];
        j--;
    }
    arr[j]=temp;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章