java與算法_Java與算法之(1) - 冒泡排序

冒泡排序法的原理是,每次比較相鄰的兩個元素,如果它們的順序錯誤就把它們交換過來。

例如對4 3 6 2 7 1 5這7個數字進行從小到大的排序,從最左側開始,首先比較4和3

c8efcb4bc1e59ff66e086e317ef25eed.png

因為是從小到大排序,4和3的順序顯然是錯誤的,交換他們,得到

8fb28926234b58a2b51ca89d6e223384.png

接下來比較4和6

58f4a3541edfa9ad5349128ef65fb63e.png

順序是正確的,不需要任何操作。接下來進行下一步,比較6和2

70964b36c5b4a29d445ab90c7a57112a.png

6顯然應該排在2的后面,怎么辦?交換它們,得到

3dd80fa410ec670d0f0a1c6db3a07d1c.png

經過前面幾步,已經可以總結出規律,那么接下來要做的比較依次是:

7 > 1? 得到 3 4 2 6 1 7 5

7 > 5? 得到

7d8e09cff75a75dab019592400c532ed.png

到此,7的右邊已經沒有數可以比較,第一輪排隊結束。經過這一輪,已經成功的把最大的數,即7放在了最后。但是前面6個數的順序還是不對,但是按照上面的思路很容易想到,對前面6個數再來一遍,即可把6放到倒數第二的位置。然后再對前面5個數重復逐個比較的步驟。。。

7個數字需要進行7-1=6次排隊,每完成一輪排隊,下一輪排隊需要比較的數字個數減1,來看代碼

public?class?BubbleSort?{

public?void?sort(int...?numbers)?{

//n個數執行n-1輪

//每一輪后完成一個數字歸位,?下一輪要比較的數字個數減1(所以內層循環是j?

int?n?=?numbers.length?-?1;

int?t;

for(int?i?=?0;?i?

for(int?j?=?0;?j?

if(numbers[j]?>?numbers[j?+?1])?{

t?=?numbers[j];

numbers[j]?=?numbers[j?+?1];

numbers[j?+?1]?=?t;

}

}

}

}

}

測試

public?static?void?main(String[]?args)?{

int[]?numbers?=?new?int[]{?4,?3,?6,?2,?7,?1,?5?};

System.out.print("before:?");

for(int?i?=?0;?i?

System.out.print(numbers[i]?+?"??");

}

System.out.println();

new?BubbleSort().sort(numbers);

System.out.print("after:?");

for(int?i?=?0;?i?

System.out.print(numbers[i]?+?"??");

}

System.out.println();

}

輸出

before:?4??3??6??2??7??1??5

after:?1??2??3??4??5??6??7

冒泡排序的核心是兩層嵌套的循環,時間復雜度是O(N^2),即對N個數排序,需要近似執行N的平方次。因為效率較低,實際開發中基本不會使用,但是因為簡單易懂通常做為學習算法的入門案例。

如果用上面的代碼對1 2 3 4 5 6 7做從小到大排列,會發現雖然數字已經排列好,但是程序還是要忠實的執行完全部兩層循環。對這種情況,我們可以引入一個變量來記錄一次內層循環中交換數字的個數,如果交換個數為0,則提前終止循環,在某些情況下可以提高效率。

public?void?betterSort(boolean?descend,?int...?numbers)?{

System.out.print("before:?");

for(int?i?=?0;?i?

System.out.print(numbers[i]?+?"??");

}

System.out.println();

//n個數執行n-1輪

//每一輪后完成一個數字歸位,?下一輪要比較的數字個數減1(所以內層循環是j?

int?n?=?numbers.length?-?1;

int?t;

int?flag?=?0;

for(int?i?=?0;?i?

for(int?j?=?0;?j?

if(descend)?{?//從大到小

if(numbers[j]?

t?=?numbers[j];

numbers[j]?=?numbers[j?+?1];

numbers[j?+?1]?=?t;

flag?=?1;

}

}?else?{

if(numbers[j]?>?numbers[j?+?1])?{

t?=?numbers[j];

numbers[j]?=?numbers[j?+?1];

numbers[j?+?1]?=?t;

flag?=?1;

}

}

}

if(flag?==?0)?{

break;

}?else?{

flag?=?0;

}

}

System.out.print("after:?");

for(int?i?=?0;?i?

System.out.print(numbers[i]?+?"??");

}

System.out.println();

}

增加一個變量需要額外占用內存空間,因此,這個方法是以空間換時間。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/259638.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/259638.shtml
英文地址,請注明出處:http://en.pswp.cn/news/259638.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Js+XML 操作

我的xml文件Login.xml如下. <?xml version"1.0" encoding"utf-8" ?><Login><Character><C Text"熱血"Value"0"></C><C Text"弱氣"Value"1"></C><C Text"激情…

Java(Android)線程池

1、new Thread的弊端執行一個異步任務你還只是如下new Thread嗎&#xff1f; [java] view plaincopy new Thread(new Runnable() { Override public void run() { // TODO Auto-generated method stub } }).start(); 那你就out太多了&#xff0c;n…

JQuery鏈式操作簡單的菜單列表

看到這個簡單的菜單demo&#xff0c;也是為了再看看JQuery對DOM的操作&#xff0c;一直都記不牢&#xff0c;特別是siblings&#xff08;&#xff09;這個總是想不起來。 這次再過一遍JQuery&#xff0c;不管簡單的還是復雜的demo 還是堅持練習一遍吧&#xff01;只為記錄&…

java 網絡編程實驗_Java網絡編程入門實驗一涉及點

1.http://www.cr173.com/html/20128_all.html 【wireshark怎么抓包、wireshark抓包詳細圖文教程】2.http://blog.csdn.net/huangjin0507/article/details/51678858 【HTTP協議1&#xff1a;工作原理】3.https://www.cnblogs.com/1666818961-lxj/p/7210021.html 【網絡常用端口號…

node.js async流程控制器--queue(隊列)

queue流程控制器是一個并行的流程控制器,但是它與parallel的區別在于queue可以控制一次執行幾個函數,而parallel只是讓所有函數并行執行. 例子如下: var q async.queue(function (obj,cb) {setTimeout(function () {console.log(obj);cb(); },obj.time) },1)for (var i 0; i&…

利用JS實現點擊上一周或下一周卻換

1.頁面加載顯示當前年份的第幾周 效果如圖&#xff1a; html代碼&#xff1a; <font size"2" color"black"> <input id"btnweek5" type"button" class"btn" value"上周" οnclick"EduCommissio…

centos7網卡編輯_CentOS7修改網卡為eth0

1.編輯網卡信息[rootlinux-node2~]#cd /etc/sysconfig/network-scripts/ #進入網卡目錄[rootlinux-node2network-scripts]# mv ifcfg-eno16777728 ifcfg-eth0 #重命名網卡名稱[rootlinux-node2 network-scripts]#cat ifcfg-eth0 #編輯網卡信息TYPEEthernetBOOTPROTOstaticDEFR…

C# 微支付退款申請接口 V3.3.6

/// <summary>/// 微支付退款申請/// </summary>/// <param name"context"></param>/// <param name"returnMsg"></param>/// <returns></returns>public bool Refund(HttpContext context, ref string r…

[轉] 英語、計算機、互聯網與全球化

http://davidzhao.blog.51cto.com/4548102/1225732 轉載于:https://www.cnblogs.com/wowk/p/3169638.html

APNIC IP 庫

http://ftp.apnic.net/apnic/stats/apnic/delegated-apnic-latest轉載于:https://www.cnblogs.com/dlwj/p/6388162.html

java reference 傳引用_Java的引用(reference)---Roni

摘自《Java面向對象編程》一書,作者:孫衛琴 來源:www.javathinker.org在JDK1.2以前的版本中&#xff0c;當一個對象不被任何變量引用&#xff0c;那么程序就無法再使用這個對象。也就是說&#xff0c;只有對象處于可觸及狀態&#xff0c;程序才能使用它。這就像在日常生活中&am…

C# 以管理員身份運行程序

剛看了一篇博友寫的“以管理員身份運行程序”, 所以我也來寫一個簡單易懂的&#xff0c;簡單兩步搞定&#xff0c;不用寫任何代碼&#xff1a; 第一步&#xff1a; 右鍵選擇項目 > 添加 > 新建項 &#xff1b; 找到 應用程序清單文件&#xff0c;后綴名為manifest&#x…

會計轉行從事IT,如何在一年時間內全職學習?

2019獨角獸企業重金招聘Python工程師標準>>> https://www.zhihu.com/question/21427478/answer/18227060 轉載于:https://my.oschina.net/soho00147/blog/836138

VS2010中使用CL快速 生成DLL的方法

方案一&#xff1a; 1、命令行中輸入cl example.cpp&#xff0c;生成example.obj和example.lib文件。有可能還會提示“沒有入口點”的錯誤。這是因為我們的CPP中是要生成dll文件的&#xff0c;并沒有main()這樣的主函數作為入口點。如果是C文件&#xff0c;則輸入cl /c exampl…

java field 獲得值_反射通用獲取字段值

像之前回答的那樣&#xff0c;您應該使用&#xff1a;Object value field.get(objectInstance);有時更喜歡的另一種方法是動態調用getter。示例代碼&#xff1a;public static Object runGetter(Field field, BaseValidationObject o){// MZ: Find the correct methodfor (Met…

android 中如何模擬back鍵

主要是在使用Fragment時能夠返回前一級&#xff0c;所以才找到了這些資料。 有兩種方式可以實現&#xff0c;直接上代碼 方法1&#xff1a; public void onBack(){new Thread(){public void run() {try{Instrumentation inst new Instrumentation();inst.sendKeyDownUpSync(Ke…

如何生成后綴表達式

如果計算一個表達式&#xff0c;比如 456*2&#xff0c;隨著計算器的不同&#xff0c;簡單的四功能計算器是30&#xff0c;許多科學計算器知道乘法的優先級高于加法&#xff0c;所以科學答案是21。典型計算順序可以是計算45&#xff0c;存為臨時變量a&#xff0c;再計算6*2&…

【原生JS插件】LoadingBar頁面頂部加載進度條

先展示一下已經實現的效果&#xff1a; 預覽地址&#xff1a;http://dtdxrk.github.io/js-plug/LoadingBar/index.html 看到手機上的瀏覽器內置了頁面的加載進度條&#xff0c;想用在pc上。 網上搜了一下&#xff0c;看到幾種頁面loading的方法&#xff1a; 1.在body頭部加入lo…

qtp啟動java程序_轉: QTP六脈神劍之調用Java程序

查看( 1147 ) /評論( 21 )六脈神劍之調用程序0Xp1zLN_0版權聲明&#xff1a;原創作品&#xff0c;轉載請以鏈接方式注明出自http://www.51testing.com/?35&#xff0c;否則將追究法律責任。51Testing軟件測試網y|X,taS51Testing軟件測試網b;|w6I"g6oK本文出自songfun的51…

Linq 數據庫操作(增刪改查)

Linq數據庫增刪改查 Linq是一種查詢語言&#xff0c;集成包含在formwork中&#xff0c;包含在C#語言中&#xff0c;它的作用是降低查詢的門檻&#xff0c;提高開發效率&#xff0c;是我們必須掌握的技術之一&#xff0c;下面是我自己對linq數據庫操作的方法&#xff0c;與大家…