久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java排序算法之冒泡排序

瀏覽:105日期:2022-08-12 14:23:34

本文實(shí)例為大家分享了java排序算法之冒泡排序的具體代碼,供大家參考,具體內(nèi)容如下

冒泡排序

冒泡排序無(wú)疑是最為出名的排序算法之一,從序列的一端開(kāi)始往另一端冒泡(你可以從左往右冒泡,也可以從右往左冒泡,看心情),依次比較相鄰的兩個(gè)數(shù)的大小(到底是比大還是比小也看你心情)

java排序算法之冒泡排序

java代碼實(shí)現(xiàn)bubblesort冒泡排序

package com.zy.test;import java.util.Arrays;public class BubbleSort { public static void main(String[] args) { System.out.println('sortTest'); int[] arr={6,3,8,2,9,1};System.out.println(Arrays.toString(arr)); for (int i=0;i<arr.length-1;i++){for (int j=0;j<arr.length-1-i;j++){ int temp = 0; if (arr[j]>arr[j+1]) {temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp; }} }System.out.println(Arrays.toString(arr)); }}

冒泡排序思路:

1、比較相鄰的元素。如果第一個(gè)比第二個(gè)大,就交換他們兩個(gè)。2、對(duì)每一對(duì)相鄰元素作同樣的工作,從開(kāi)始第一對(duì)到結(jié)尾的最后一對(duì)。這步做完后,最后的元素會(huì)是最大的數(shù)。3、針對(duì)所有的元素重復(fù)以上的步驟,除了最后一個(gè)。4、持續(xù)每次對(duì)越來(lái)越少的元素重復(fù)上面的步驟,直到?jīng)]有任何一對(duì)數(shù)字需要比較。

Java實(shí)現(xiàn)冒泡排序優(yōu)化

冒泡有一個(gè)最大的問(wèn)題就是這種算法不管不管你有序還是沒(méi)序,閉著眼睛把你循環(huán)比較了再說(shuō).

比如我舉個(gè)數(shù)組例子:[ 5,6,7,8,9 ],一個(gè)有序的數(shù)組,根本不需要排序,它仍然是雙層循環(huán)一個(gè)不少的把數(shù)據(jù)遍歷干凈,這其實(shí)就是做了沒(méi)必要做的事情,屬于浪費(fèi)資源。

針對(duì)這個(gè)問(wèn)題,我們可以設(shè)定一個(gè)臨時(shí)遍歷來(lái)標(biāo)記該數(shù)組是否已經(jīng)有序,如果有序了就不用遍歷了。

package com.zy.test;import java.util.Arrays;public class BubbleSort { public static void main(String[] args) { System.out.println('sortTest'); int[] arr={6,3,8,2,9,1};System.out.println(Arrays.toString(arr)); for (int i=0;i<arr.length-1;i++){boolean flag=true;for (int j=0;j<arr.length-1-i;j++){ int temp = 0; if (arr[j]>arr[j+1]) {flag=false;temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp; }}if (flag){ break;} }System.out.println(Arrays.toString(arr)); }}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 常州市| 体育| 普宁市| 云和县| 永仁县| 合水县| 阿瓦提县| 天柱县| 连江县| 承德市| 武邑县| 台中市| 申扎县| 澳门| 成安县| 南开区| 攀枝花市| 桐庐县| 彭水| 茶陵县| 保定市| 通许县| 渭源县| 宝山区| 连平县| 贞丰县| 革吉县| 临泽县| 塔城市| 峨眉山市| 乡城县| 旺苍县| 双流县| 蓝山县| 周口市| 宿迁市| 罗江县| 城步| 荔浦县| 千阳县| 陆丰市|