大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 編程技術分享之Java簡單算法的學習

編程技術分享之Java簡單算法的學習

更新時間:2020-06-23 12:50:06 來源:動力節點 瀏覽2054次

排序算法可以分為內部排序和外部排序,內部排序是數據記錄在內存中進行排序,而外部排序是因排序的數據很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存。常見的內部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序!

編程技術分享之Java簡單算法的學習

1.排序

(1)冒泡排序

重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。時間復雜度O(n2),為穩定算法。

將數依次進行比較,并將大(或小)的,網后放,如下:

public static void bubbleSort(int[]arr){
for(int i=0;i<arr.length-1;i++){
for(int j=0;j<arr.length-i-1;j++){
//-1為了防止溢出
if(arr[j]>arr[j+1]){
//把大的數放在后面
int temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}

(2)快速排序

通過一趟排序將要排序的數據分割成獨立的兩部分,其中一部分的所有數據都比另外一部分的所有數據都要小,然后再按此方法對這兩部分數據分別進行快速排序,整個排序過程可以遞歸進行,以此達到整個數據變成有序序列。

public static void quickSort(int[]numbers,int low,int high){
if(low<high){
int middle=getMiddle(numbers,low,high);
//將numbers數組進行一分為二
quickSort(numbers,low,middle-1);
//對低字段表進行遞歸排序
quickSort(numbers,middle+1,high);
//對高字段表進行遞歸排序
}
}

(3)選擇排序

每一次從待排序的數據元素中選出最小(或最大)的一個元素,存放在序列的起始位置,直到全部待排序的數據元素排完。選擇排序是不穩定的排序方法(比如序列[5,5,3]第一次就將第一個[5]與[3]交換,導致第一個5挪動到第二個5后面)。

public static void selectSort(int[]a){
int minIndex=0;
int temp=0;
for(int i=0;i<a.length-1;i++){
minIndex=i;
//無序區的最小數據數組下標
for(intj=i+1;j<a.length;j++){
//在無序區中找到最小數據并保存其數組下標
if(a[j]<a[minIndex]){
minIndex=j;
}
}

//將最小元素放到本次循環的前端
temp=a;
a=a[minIndex];
a[minIndex]=temp;
}
}

(4)插入排序

每步將一個待排序的記錄,按其順序碼大小插入到前面已經排序的字序列的合適位置(從后向前找到合適位置后),直到全部插入排序完為止。

每一個數和它前面的數依次進行比較,因為前面的數的順序是已經排好的

private static int[]insertSort(int[]arr){
for(int i=1;i<arr.length;i++){
for(int j=i;j>0;j--){
if(arr[j]<arr[j-1]){
int temp=arr[j];
arr[j]=arr[j-1];
arr[j-1]=temp;
}else{
break;
}
}
}
return arr;
}

(5)希爾排序

把記錄按下標的一定增量分組,對每組使用直接插入排序算法排序;隨著增量逐漸減少,每組包含的關鍵詞越來越多,當增量減至1時,整個文件恰被分成一組,算法便終止。

public static void main(String[]args)
{
int[]a={49,38,65,97,76,13,27,49,78,34,12,64,1};
//希爾排序
int d=a.length;
while(true){
d=d/2;
for(int x=0;x<d;x++){
for(int i=x+d;i<a.length;i=i+d){
int temp=a;
int j;
for(j=i-d;j>=0&&a[j]>temp;j=j-d){
a[j+d]=a[j];
}
a[j+d]=temp;
}
}
if(d==10){
break;
}
}
}

(6)歸并排序

建立在歸并操作上的一種有效的排序算法,該算法是采用分治法(Divide and Conquer)的一個非常典型的應用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為二路歸并。時間復雜度O(n log n)。

public static int[]sort(int[]nums,int low,int high){
int mid=(low+high)/2;
if(low<high){
//左邊
sort(nums,low,mid);
//右邊
sort(nums,mid+1,high);
//左右歸并
merge(nums,low,mid,high);
}
return nums;
}

以上就是動力節點java培訓機構的小編針對“編程技術分享之Java簡單算法的學習”的內容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久久91视频| 波多野结衣二区 | 精品国产品香蕉在线 | 免费国产成人高清在线观看视频 | 激情欧美一区二区三区中文字幕 | 日韩欧美无线在码 | 久久久网| 亚洲免费在线播放 | 欧美日韩激情在线一区二区 | 国产精品久久亚洲不卡动漫 | 超碰在线小说 | 亚洲国产精品乱码一区二区三区 | 一本大道高清香蕉中文大在线 | 国产日韩在线看 | 天天干天天拍天天射天天添天天爱 | 色偷偷88888欧美精品久久久 | 成年午夜视频免费观看视频 | 国产边打电话边被躁视频 | 在线精品欧美 | 精品在线播放 | 亚洲国产精品不卡毛片a在线 | 免费一看一级毛片 | 日韩欧美高清在线 | 天天在线天天综合网色 | 99久久精品国产自免费 | 欧美一区二区三区免费视频 | 日韩亚洲在线 | 成人影院免费观看 | 一级做a爰片性色毛片2021 | 欧美一级午夜免费视频你懂的 | 精品乱人伦一区二区三区 | 天天干天天曰天天操 | 久久性生活片 | 在线观看亚洲视频 | 交专区videossex另类 | 欧美一级免费 | 欧美一级视频在线观看 | 日日摸日日添日日透 | 久久久日本精品一区二区三区 | 啪啪网站色大全免费 | 日日私人影院 |