Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章

上傳人:jun****875 文檔編號(hào):23558357 上傳時(shí)間:2021-06-09 格式:PPT 頁數(shù):104 大小:808.50KB
收藏 版權(quán)申訴 舉報(bào) 下載
Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章_第1頁
第1頁 / 共104頁
Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章_第2頁
第2頁 / 共104頁
Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章_第3頁
第3頁 / 共104頁

下載文檔到電腦,查找使用更方便

14.9 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章》由會(huì)員分享,可在線閱讀,更多相關(guān)《Java語言程序設(shè)計(jì)-基礎(chǔ)篇-中文ppt-第六章(104頁珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、第6章 一維數(shù)組 開放問題讀取一百數(shù)字,計(jì)算它們的平均值,然后找出有多少個(gè)數(shù)大于平均值。 解決方案 Run 學(xué)習(xí)目標(biāo)F描述數(shù)組在程序設(shè)計(jì)中的必要性 (第6.1節(jié))。F聲明數(shù)組引用變量、創(chuàng)建數(shù)組 (第6.2.1-6.2.2節(jié))。F初始化數(shù)組中的值 (第6.2.3節(jié))。F使用下標(biāo)變量訪問數(shù)組元素(第6.2.4節(jié))。F利用一條數(shù)組初始化語法聲明、創(chuàng)建和初始化數(shù)組 (第6.2.5節(jié))。F編寫程序?qū)崿F(xiàn)常用的數(shù)組操作(顯示數(shù)組、對(duì)所有元素求和、求最大和最小元素、隨意打亂、移動(dòng)元素)(第6.2.6節(jié) )。F使用for - each循環(huán)簡化程序設(shè)計(jì)(第6.2.7)。F在LottoNumbers和DeckOfC

2、ards問題中應(yīng)用數(shù)組 (第6.3-6.4節(jié))。F將一個(gè)數(shù)組的內(nèi)容復(fù)制到另一個(gè)數(shù)組 (第6.5節(jié))。 F開發(fā)和調(diào)用帶數(shù)組參數(shù)和返回值的方法(第6.66.7節(jié))。F定義帶變長參數(shù)列表的方法(第6.8節(jié))。F使用線性查找算法(第6 .9.1節(jié))或二分查找算法(第6. 9.2節(jié))查找數(shù)組的元素。F使用選擇排序法對(duì)數(shù)組排序(第6.10.1節(jié))。F使用插入排序算法使排序數(shù)組 (第6.10.2節(jié))。F使用 Arrays 類中的方法(第6.11節(jié))。 介紹數(shù)組數(shù)組是一種數(shù)據(jù)結(jié)構(gòu),它表示一組相同類型的數(shù)據(jù)。 5.6 4.5 3.3 13.2 4 34.33 34 45.45 99.993 11123 doub

3、le myList = new double10; myList reference myList0 myList1 myList2 myList3 myList4 myList5 myList6 myList7 myList8 myList9 元素值 數(shù)組引用變量 下標(biāo)5處的 數(shù)組元素 聲明數(shù)組變量Fdatatype arrayRefVar;舉例: double myList;Fdatatype arrayRefVar; / 這種風(fēng)格是允許的,但不推薦使用舉例: double myList; 創(chuàng)建數(shù)組arrayRefVar = new datatypearraySize;舉例:myList

4、= new double10;myList0 引用數(shù)組中的第一個(gè)元素。myList9 引用數(shù)組中的最后一個(gè)元素。 一步完成聲明和創(chuàng)建Fdatatype arrayRefVar = new datatypearraySize; double myList = new double10;Fdatatype arrayRefVar = new datatypearraySize;double myList = new double10; 數(shù)組的大小一旦數(shù)組被創(chuàng)建就不能再修改它的大小??梢酝ㄟ^使用arrayRefVar.length來求得數(shù)組的大小。舉例:myList.length returns 1

5、0 默認(rèn)值當(dāng)數(shù)組被創(chuàng)建后,它的元素被賦予默認(rèn)值 數(shù)值型基本數(shù)據(jù)類型的默認(rèn)值是0, char 類型的默認(rèn)值為u0000 ,而 boolean 類型默認(rèn)值為false。 下標(biāo)變量數(shù)組元素可以通過下標(biāo)來訪問。數(shù)組下標(biāo)是基于0的,就是說它從0開始到arrayRefVar.length-1結(jié)束。在圖6.1中的例子中, 數(shù)組myList 包含10個(gè)double值而下標(biāo)是從0到9。數(shù)組中的每個(gè)元素都可以使用下面一般被稱為下標(biāo)變量的語法表示:arrayRefVarindex; 使用下標(biāo)變量創(chuàng)建數(shù)組后,可以采用和一般變量相同的方法使用下標(biāo)變量。例如:下面的代碼是將myList0和myList1的值相加賦給myL

6、ist2。myList2 = myList0 + myList1; 數(shù)組初始化語法F一步完成數(shù)組的聲明、創(chuàng)建、初始化:double myList = 1.9, 2.9, 3.4, 3.5;這種縮略語法必須用在一條語句中。 使用縮略符號(hào)聲明、創(chuàng)建、初始化數(shù)組double myList = 1.9, 2.9, 3.4, 3.5;這里的縮略符號(hào)相當(dāng)于以下面的語句:double myList = new double4;myList0 = 1.9;myList1 = 2.9;myList2 = 3.4;myList3 = 3.5; 注意 使用縮略符號(hào)時(shí),你必須將聲明、創(chuàng)建和初始化數(shù)組都放在一條語句中。

7、將它們分開會(huì)引起語法錯(cuò)誤。例如:下面的語句就是錯(cuò)誤的:double myList;myList = 1.9, 2.9, 3.4, 3.5; 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 聲明數(shù)組變量value,創(chuàng)建一個(gè)數(shù)組并將它的引用賦值給values動(dòng) 畫 跟蹤數(shù)組程序public class Test public

8、 static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i 變?yōu)?1動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + val

9、ues4; i (=1)小于5動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這一行被執(zhí)行后,values1是1 After the first iteration 0 1 2 3 4 0 1 0 0 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(St

10、ring args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i+后,i 變?yōu)?2動(dòng) 畫 After the first iteration 0 1 2 3 4 0 1 0 0 0 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valu

11、esi-1; values0 = values1 + values4; i(= 2)小于5動(dòng) 畫 After the first iteration 0 1 2 3 4 0 1 0 0 0 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這一行被執(zhí)行之后,values2 為3(2 + 1) After the secon

12、d iteration 0 1 2 3 4 0 1 3 0 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這之后,i就 變?yōu)?3. After the second iteration 0 1 2 3 4 0 1 3 0 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static

13、 void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i(=3)依舊小于5 After the second iteration 0 1 2 3 4 0 1 3 0 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) val

14、uesi = i + valuesi-1; values0 = values1 + values4; 這一行之后,values3變成 6(3 + 3) After the third iteration 0 1 2 3 4 0 1 3 6 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這之后,i變成4 Af

15、ter the third iteration 0 1 2 3 4 0 1 3 6 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i(=4) 仍舊小于5 After the third iteration 0 1 2 3 4 0 1 3 6 0 動(dòng) 畫 跟蹤數(shù)組程序public class Test pub

16、lic static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這之后,values4變成 10(4 + 6) After the fourth iteration 0 1 2 3 4 0 1 3 6 10 動(dòng) 畫 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for

17、(int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i+后,i 變成5動(dòng) 畫 After the fourth iteration 0 1 2 3 4 0 1 3 6 10 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; i

18、 ( =5) 5 為假。退出循環(huán)動(dòng) 畫 After the fourth iteration 0 1 2 3 4 0 1 3 6 10 跟蹤數(shù)組程序public class Test public static void main(String args) int values = new int5; for (int i = 1; i 5; i+) valuesi = i + valuesi-1; values0 = values1 + values4; 這行之后,values0 為11 (1 + 10) 0 1 2 3 4 11 1 3 6 10 動(dòng) 畫 處理數(shù)組下面是一些示例:F(使用輸

19、入值初始化數(shù)組)F(使用隨機(jī)數(shù)初始化數(shù)組)F(打印數(shù)組)F(對(duì)所有元素求和)F(找出最大元素)F(找出最大元素的最小下標(biāo)值) F(隨意打亂) 1.(移動(dòng)元素) 使用輸入值初始化數(shù)組java.util.Scanner input = new java.util.Scanner(System.in);System.out.print(Enter + myList.length + values: );for (int i = 0; i myList.length; i+) myListi = input.nextDouble(); 使用隨機(jī)數(shù)初始化數(shù)組for (int i = 0; i myLis

20、t.length; i+) myListi = Math.random() * 100; 打印數(shù)組for (int i = 0; i myList.length; i+) System.out.print(myListi + ); 對(duì)所有元素求和double total = 0;for (int i = 0; i myList.length; i+) total += myListi; 找出最大的元素double max = myList0;for (int i = 1; i max) max = myListi; 隨意打亂 for (int i = 0; i myList.length; i

21、+) / Generate an index j randomly int index = (int)(Math.random() * myList.length); / Swap myListi with myListj double temp = myListi; myListi = myListindex; myListindex = temp; myList 0 1 . . . index A random index i swap 移動(dòng)元素 double temp = myList0; / Retain the first element / Shift elements left

22、for (int i = 1; i myList.length; i+) myListi - 1 = myListi; / Move the first element to fill in the last position myListmyList.length - 1 = temp; myList 增強(qiáng)型for循環(huán)(for - each循環(huán))JDK 1.5引入了一個(gè)新的for循環(huán),它可以讓你不使用下標(biāo)變量就可以順序地遍歷整個(gè)數(shù)組。 例如:下面的代碼顯示數(shù)組myList中的所有元素: for (double value: myList) System.out.println(value);

23、 一般來講,這個(gè)語法是 for (elementType value: arrayRefVar) / Process the value 當(dāng)需要以其它順序遍歷該數(shù)組或改變數(shù)組中的元素時(shí),你還是必須使用下標(biāo)變量。 問題:樂透號(hào)碼假設(shè)你要玩選10樂透游戲,每張籌碼有10個(gè)范圍從1到99的獨(dú)特的數(shù)字。假設(shè)你買了一堆籌碼,希望它們涵蓋1到99的所有數(shù)字。編寫一個(gè)程序,從一個(gè)文件中讀取籌碼上的數(shù)字,并檢查是否涵蓋所有的數(shù)字。 假設(shè)這個(gè)文件的最后一個(gè)數(shù)字是0。 問題:一副牌編寫一個(gè)程序,它隨機(jī)地從一副52張牌中選擇4張。所有的牌可以使用一個(gè)名為deck的數(shù)組表示,這個(gè)數(shù)組用從0到51的初始值來填充,如下所

24、示:int deck = new int52;/ Initialize cardsfor (int i = 0; i deck.length; i+) decki = i; 問題:一副牌(續(xù)) 0 . . . 12 13 . . . 25 26 . . . 38 39 . . . 51 13 Spades (?) 13 Hearts (?) 13 Diamonds (?) 13 Clubs (?) 0 . . . 12 13 . . . 25 26 . . . 38 39 . . . 51 deck 0 . . . 12 13 . . . 25 26 . . . 38 39 . . . 51

25、Random shuffle 6 48 11 24 . . . . . . . . . . . . . . . . deck 0 1 2 3 4 5 . . . 25 26 . . . 38 39 . . . 51 Card number 6 is 7 of Spades Card number 48 is 10 of Clubs Card number 11 is Queen of Spades Card number 24 is Queen of Hearts 問題:一副牌這個(gè)問題為今后構(gòu)建一個(gè)更有趣和更具現(xiàn)實(shí)意義的應(yīng)用程序打一個(gè)基礎(chǔ):參見練習(xí)題25.9。 復(fù)制數(shù)組在程序中,你經(jīng)常需要復(fù)制

26、一個(gè)數(shù)組或數(shù)組的一部分。在這種情況下,你可能會(huì)嘗試使用賦值語句(=),如下所示: list2 = list1; list1 的內(nèi)容 list1 list2 的內(nèi)容 list2 賦值語句 list2 = list1;之前 list1 的內(nèi)容 list1 list2 的內(nèi)容 list2 賦值語句 list2 = list1;之后 Garbage 復(fù)制數(shù)組使用循環(huán):int sourceArray = 2, 3, 1, 5, 10;int targetArray = new intsourceArray.length;for (int i = 0; i sourceArrays.length; i+)

27、 targetArrayi = sourceArrayi; arraycopy工具arraycopy(sourceArray, src_pos, targetArray, tar_pos, length);例如:System.arraycopy(sourceArray, 0, targetArray, 0, sourceArray.length); 傳遞數(shù)組給方法public static void printArray(int array) for (int i = 0; i array.length; i+) System.out.print(arrayi + ); Invoke the

28、methodint list = 3, 1, 2, 6, 4, 2;printArray(list);Invoke the method printArray(new int3, 1, 2, 6, 4, 2);匿名數(shù)組 匿名數(shù)組語句printArray(new int3, 1, 2, 6, 4, 2); 使用下面的語法創(chuàng)建一個(gè)數(shù)組:new dataTypeliteral0, literal1, ., literalk;這里沒有數(shù)組的顯式引用變量。這樣的數(shù)組被稱為匿名數(shù)組。 值傳遞Java使用值傳遞的方法傳遞實(shí)參給方法。傳遞基本數(shù)據(jù)類型變量的值與傳遞數(shù)組值會(huì)有很大不同。F 對(duì)于基本數(shù)據(jù)類型參數(shù),

29、傳遞的是實(shí)參的值。在方法中改變局部參數(shù)的值并不影響方法之外變量的值。F 對(duì)于數(shù)組類型參數(shù),參數(shù)值是數(shù)組的引用,傳遞給方法的是這個(gè)引用。方法體中數(shù)組發(fā)生的改變,將會(huì)影響到作為參數(shù)傳給方法的原始數(shù)組。 public class Test public static void main(String args) int x = 1; / x represents an int value int y = new int10; / y represents an array of int values m(x, y); / Invoke m with arguments x and y System.

30、out.println(x is + x); System.out.println(y0 is + y0); public static void m(int number, int numbers) number = 1001; / Assign a new value to number numbers0 = 5555; / Assign a new value to numbers0 簡單的例子 調(diào)用棧 當(dāng)調(diào)用m(x,y)時(shí),x和y的值被傳遞給 number 和 numbers。因?yàn)閥包含的是數(shù)組的引用值,所以,numbers現(xiàn)在包含的是指向同一數(shù)組的相同引用值。 Space requi

31、red for the main method int y: int x: 1 棧 Space required for method m int numbers: int number: 1 reference 0 0 0 The arrays are stored in a heap. 堆 reference Array of ten int values is 調(diào)用棧當(dāng)調(diào)用m(x,y)時(shí),x和y的值被傳遞給 number 和 numbers。因?yàn)閥包含的是數(shù)組的引用值,所以,numbers現(xiàn)在包含的是指向同一數(shù)組的相同引用值。 Space required for the main me

32、thod int y: int x: 1 Stack Space required for method m int numbers: int number: 1001 reference 5555 0 0 The arrays are stored in a heap. Heap reference Array of ten int values is stored here 堆 Space required for the main method int y: int x: 1 reference The arrays are stored in a heap. Heap 5555 0 0

33、 JVM將數(shù)組存儲(chǔ)在一個(gè)被稱作堆的內(nèi)存區(qū)域,堆是用來動(dòng)態(tài)分配內(nèi)存的,在堆中的內(nèi)存塊可以按任意順序分配和釋放。 傳遞數(shù)組參數(shù)F目標(biāo):演示傳遞基本數(shù)據(jù)類型變量和傳遞數(shù)組變量的不同之處。 舉例(續(xù)) Invoke swap(int n1, int n2). The primitive type values in a0 and a1 are passed to the swap method. Space required for the main method int a Stack Space required for the swap method n2: 2 n1: 1 reference

34、a1: 2 a0: 1 The arrays are stored in a heap. Invoke swapFirstTwoInArray(int array). The reference value in a is passed to the swapFirstTwoInArray method. Heap Space required for the main method int a Stack Space required for the swapFirstTwoInArray method int array reference reference 從方法中返回?cái)?shù)組public

35、 static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 跟蹤reverse方法public static int reverse(int list) int result = new intli

36、st.length; for (int i = 0, j = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = 1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 0聲明result 并創(chuàng)建數(shù)組 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for

37、(int i = 0, j = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 0 i = 0 而 j = 5 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i =

38、 0, j = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 0 i (= 0) 小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = re

39、sult.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 1 i = 0 而 j = 5 將list0賦值給result5 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i =

40、0, j = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 1這之后,i 變?yōu)? 而 j 變?yōu)?4 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j

41、 = result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 0 1 i(=1)小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.len

42、gth - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 2 1 i = 1 而 j = 4 將list1賦值給給 result4 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j =

43、 result.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 2 1這之后,i 變成2 而 j 變?yōu)?3 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = res

44、ult.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 0 2 1 i (=2) 依舊小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.lengt

45、h - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 3 2 1 i = 2 而 j = 3 將listi賦值給 resultj 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = re

46、sult.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 3 2 1這之后,i 變成 3 而 j 變成 2 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = resul

47、t.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 0 3 2 1 i(=3)依舊小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length -

48、1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 4 3 2 1 i = 3 而 j = 2 將listi賦值給 resultj 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result

49、.length - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 4 3 2 1這之后,i 變成 4 而 j 變成 1 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.le

50、ngth - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 0 4 3 2 1 i(=4)依舊小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length - 1; i

51、 list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 5 4 3 2 1 i = 4 而 j = 1 將listi賦值給 resultj 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.len

52、gth - 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 5 4 3 2 1這之后,i變成5 而 j 變成 0 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length -

53、 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 60 5 4 3 2 1 i (=5) 依舊小于6 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length - 1; i lis

54、t.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 66 5 4 3 2 1 i = 5 而 j = 0 將listi賦值給resultj 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length -

55、 1; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 66 5 4 3 2 1這之后, i 變成 6 而j 變成 -1 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length - 1

56、; i list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 66 5 4 3 2 1 i(=6) 6 為假,所以退出循環(huán) 動(dòng) 畫 跟蹤reverse方法(續(xù))public static int reverse(int list) int result = new intlist.length; for (int i = 0, j = result.length - 1; i

57、list.length; i+, j-) resultj = listi; return result; int list1 = new int1, 2, 3, 4, 5, 6;int list2 = reverse(list1);listresult 1 2 3 4 5 66 5 4 3 2 1返回 resultlist2 動(dòng) 畫 問題:統(tǒng)計(jì)每個(gè)字母出現(xiàn)的次數(shù)F隨機(jī)生成100個(gè)小寫字母,將它們賦值給一個(gè)字符數(shù)組。F統(tǒng)計(jì)數(shù)組中的每個(gè)字母的出現(xiàn)計(jì)數(shù)。 (a) Executing createArray in Line 6 Space required for the main method ch

58、ar chars: ref Heap Array of 100 characters Space required for the createArray method char chars: ref (b) After exiting createArray in Line 6 Space required for the main method char chars: ref Heap Array of 100 characters Stack Stack 數(shù)組的搜索 public class LinearSearch /* The method for finding a key in

59、the list */ public static int linearSearch(int list, int key) for (int i = 0; i list.length; i+) if (key = listi) return i; return -1; list key 將key 和 listi for i = 0, 1, 進(jìn)行比較 0 1 2 搜索就是在數(shù)組中尋找特定元素的過程;例如:判斷某一特定分?jǐn)?shù)是否包含在成績列表中。搜索是計(jì)算機(jī)程序設(shè)計(jì)中一種經(jīng)常要完成的任務(wù)。有許多關(guān)于搜索的算法和數(shù)據(jù)結(jié)構(gòu)。在本節(jié)中,討論兩種常用的方法:線性查找法和二分查找法。 線性查找法線性查找法就是

60、將要查找的關(guān)鍵元素key順序地與數(shù)組list中的每一個(gè)元素進(jìn)行比較。這個(gè)方法一直繼續(xù)直到在列表中找到與關(guān)鍵字匹配的元素,還有一種情況就是忙乎了半天,在list中也沒找到匹配的元素。如果匹配成功,線性查找法返回與數(shù)組中與關(guān)鍵字匹配的元素的下標(biāo)。 如果匹配不成功,則返回 -1。 線性查找法的動(dòng)畫6 4 1 9 7 3 2 86 4 1 9 7 3 2 86 4 1 9 7 3 2 86 4 1 9 7 3 2 86 4 1 9 7 3 2 86 4 1 9 7 3 2 83333 33 動(dòng) 畫Key List 從想法到解決方案/* The method for finding a key in t

61、he list */public static int linearSearch(int list, int key) for (int i = 0; i list.length; i+) if (key = listi) return i; return -1;int list = 1, 4, 4, 2, 5, -3, 6, 2; int i = linearSearch(list, 4); / returns 1int j = linearSearch(list, -4); / returns -1int k = linearSearch(list, -3); / returns 5跟蹤這

62、個(gè)方法 二分查找法使用二分查找法的前提是數(shù)組中的元素必須已經(jīng)被排好序。為不時(shí)一般性,假設(shè)數(shù)組以升序排序。例如: 2 4 7 10 11 45 50 59 60 66 69 70 79二分查找法首先將關(guān)鍵字key與數(shù)組中間的元素進(jìn)行比較。 二分查找法(續(xù))F如果關(guān)鍵字key小于中間元素,你只需要在數(shù)組的前半部分的元素中繼續(xù)查找關(guān)鍵字。F如果關(guān)鍵字key等于中間元素,這個(gè)查找結(jié)束。F如果關(guān)鍵字key大于中間元素,你只需要在數(shù)組的后半部分的元素中繼續(xù)查找關(guān)鍵字??紤]下面三種情況: 二分查找法1 2 3 4 6 7 8 91 2 3 4 6 7 8 91 2 3 4 6 7 8 9888Key Lis

63、t動(dòng) 畫 二分查找法(續(xù)) 0 1 2 3 4 5 6 7 8 9 10 11 12 2 4 7 10 11 45 50 59 60 66 69 70 79 key 是 11 key 7 key = 11 high low mid high low list 3 4 5 mid high low list 2 4 7 10 11 45 10 11 45 Binary Search, cont. 0 1 2 3 4 5 6 7 8 9 10 11 12 2 4 7 10 11 45 50 59 60 66 69 70 79 key 是 54 key 50 list mid 0 1 2 3 4 5

64、 6 7 8 9 10 11 12 key 66 key = low) int mid = (low + high) / 2; if (key listmid) high = mid - 1; else if (key = listmid) return mid; else low = mid + 1; return -1 - low; 方法Arrays.binarySearch由于二分查找法經(jīng)常在程序設(shè)計(jì)中用到,所以Java在類java.util.Arrays提供了方法binarySearch的幾個(gè)重載方法,它們可以在由 int、double、char、short、long,和 float

65、構(gòu)成數(shù)組中搜索關(guān)鍵字。例如:下面的代碼在包含數(shù)字的數(shù)組和包含字符的數(shù)組中查找關(guān)鍵字。int list = 2, 4, 7, 10, 11, 45, 50, 59, 60, 66, 69, 70, 79;System.out.println(Index is + java.util.Arrays.binarySearch(list, 11); char chars = a, c, g, x, y, z;System.out.println(Index is + java.util.Arrays.binarySearch(chars, t); 為使binarySearch正常運(yùn)轉(zhuǎn),必須使數(shù)組按升序

66、排列。 返回 4返回 4 (返回點(diǎn)是3,所以返回 -3-1) 數(shù)組的排序像查找一樣,排序在計(jì)算機(jī)程序設(shè)計(jì)中也是一個(gè)常用任務(wù)。已經(jīng)開發(fā)出許多不同的排序算法。 本節(jié)將介紹兩種簡單的、直觀的排序算法:選擇排序法和插入排序法。 選擇排序就是找到數(shù)列中的最小數(shù)并將它放在最前面。 然后找到剩余數(shù)中最小的并將它放到最前面第二位,直到數(shù)列中只包含一個(gè)數(shù)字。 圖6.17顯示如何使用選擇排序法對(duì)隊(duì)列 2、9、5、4、8、1、6 進(jìn)行排序。選擇排序法 2 9 5 4 8 1 6 swap Select 1 (the smallest) and swap it with 2 (the first) in the list 1 9 5 4 8 2 6 swap The number 1 is now in the correct position and thus no longer needs to be considered. 1 2 5 4 8 9 6 swap 1 2 4 5 8 9 6 Select 2 (the smallest) and swap it with 9 (the first) in

展開閱讀全文
溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!