## Java編程那些事兒45—數組使用示例1
鄭州游戲學院 陳躍峰
出自:[http://blog.csdn.net/mailbomb](http://blog.csdn.net/mailbomb)
**6.3 數組使用示例**
本部分通過一系列的示例,熟悉數組的基本語法,并演示一些使用數組可以解決的基本問題。在實際使用數組時,數組的長度以及數組中每個元素存儲的數據,都根據邏輯需要進行設計。
**6.3.1 循環初始化數組元素**
要求:初始化一個長度為100的int數組,數組中的元素依次為1-100。
這是一個基本的使用,主要是熟悉數組的語法,在實際編寫時,需要發現數組下標和數組元素值之間的規律即可。
第一種思路:循環數組的下標0-99,則和下標對應的元素的值比數組下標多1。
則實現代碼如下:
~~~
?????????????????? int[] m = new int[100];
?????????????????? for(int i = 0;i < m.length;i++){
??????????????????????????? m[i] = i + 1;
?????????????????? }
~~~
代碼說明:聲明并初始化一個長度是100的數組,使用循環循環數組的下標,下標的區間是[0,m.length-1],其中m.length表示數組的長度。在實際賦值時,把數組的下標做成變量,則當i的值為0時,則m[i]就是m[0],依次類推,按照題目的要求,則數值的規律是i+1,這樣循環結束以后,數組m中的值就依次是1-100了。
第二種思路:循環數組的值1-100,則下標比數組的值下1。
則實現的代碼如下:
~~~
?????????????????? int[] m = new int[100];
?????????????????? for(int i = 1;i <= 100;i++){
??????????????????????????? m[i – 1] = i;
?????????????????? }
~~~
該代碼中循環變量i的值從1循環到100,則數組的下標是i – 1,這樣也可以實現題目要求的功能。
**6.3.2輸出數列**
要求:輸出1 1 2 3 5 8 13……這樣的數列,輸出該數列的前20個數字。
該題是一個基本的數字邏輯,在實際解決該問題時,首先要發現該數字的規律,然后按照該規律來設計數組即可。
實現思路:數字的規律是除了數列里的前兩個數字以外,其它的數字都滿足該數字等于前兩個數字的和,由于題目要求輸出前20個數字,所以需要一個長度為20的數組,第一個和第二個數字直接賦值,后續的數字通過前兩個數字元素得到。
則實現的代碼如下:
~~~
?????????????????? int[] num = new int[20];
?????????????????? num[0] = 1;
?????????????????? num[1] = 1;
?????????????????? //循環初始化
for(int i = 2;i < num.length;i++){
??????????????????????????? num[i] = num[i – 1] + num[i – 2];
?????????????????? }
?????????????????? //循環輸出
for(int i = 0;i < num.length;i++){
??????????????????????????? System.out.print(num[i]);
??????????????????????????? System.out.print(‘ ‘);
?????????????????? }
?????????????????? System.out.println();?//換行
~~~
在該代碼中,初始化一個長度為20的數組,首先將數組中的前兩個元素賦值成1,然后循環對后續的元素的賦值,如果當前元素的下標是i,則它前一個元素的下標是i-1,再前面一個元素的下標是i-2,只需要將這2個元素的值相加,然后賦值給當前元素即可。后面使用一個循環,輸出數組中所有的元素,元素和元素之間有一個間隔的空格,在輸出所有的元素以后換行。
**6.3.3 歌手打分**
要求:在歌唱比賽中,共有10位評委進行打分,在計算歌手得分時,去掉一個最高分,去掉一個最低分,然后剩余的8位評委的分數進行平均,就是該選手的最終得分。如果已知每個評委的評分,求該選手的得分。
該題實際上涉及到求數組的最大值、最小值,以及求數組中所有元素的和,也是數組方便統計的用途體現。
實現思路:求出數組元素的最大值、最小值以及和,然后使用和減去最大值和最小值,然后除以8獲得得分。
則實現的代碼如下:
~~~
?????????????????? int[] score = {90,78,90,96,67,86,78,92,79,85};?//評委打分
?????????????????? int sum = 0;????? ??//存儲和
?????????????????? int max =score[0]; ?//存儲最大值
?????????????????? int min = score[0];?//存儲最小值
?????????????????? //求和
?????????????????? for(int i = 0;i < score.length;i++){
??????????????????????????? sum += score[i];
?????????????????? }
?????????????????? //獲得最大值
?????????????????? for(int i = 1;i < score.length;i++){
??????????????????????????? //比較
??????????????????????????? if(max < score[i]){???????????????????????????????????? max = score[i];
??????????????????????????? }
?????????????????? }
?????????????????? //獲得最小值
?????????????????? for(int i = 1;i < score.length;i++){
??????????????????????????? //比較
??????????????????????????? if(min > score[i]){???????????????????????????????????? min = score[i];
??????????????????????????? }
?????????????????? }
?????????????????? //計算平均分
?????????????????? double avg = (sum – max – min)/8.0;
?????????????????? System.out.println(avg);
~~~
在該代碼中,實現數組求和的思路和以前的一樣,就是每次加一個元素,然后用得到的結果再和后續的元素依次相加。求最大值的思路是首先假設第一個元素最大,把score[0]賦值給max,然后使用max的值和后續依次比較,如果后續的元素比max大,則把該值賦值給max,然后再和后續的元素比較,求最小值的思路和最大值的思路一樣。然后計算平均分就完成了題目的要求。
該代碼雖然結構比較清晰,但是效率不高,為了追求效率,可以把以上三個循環合并起來,代碼如下:
~~~
?????????????????? for(int i = 0;i < score.length;i++){
??????????????????????????? sum += score[i]; //求和
??????????????????????????? //獲得最大值
??????????????????????????? if(max < score[i]){???????????????????????????????????? max = score[i];
??????????????????????????? }
??????????????????????????? //獲得最小值
??????????????????????????? if(min > score[i]){??????????????????????????? ???????? min = score[i];
??????????????????????????? }
?????????????????? }
~~~
這樣雖然在結構上稍微復雜了一些,但是效率得到了改善。在實際編寫程序時,一般會在功能書寫完成以后,對代碼進行優化,提高程序的執行效率。
- 前言
- (1)序言
- (2)程序設計是什么?
- (3)你適合學習程序設計嗎?
- (4)如何學好程序設計?
- (5)程序設計介紹小結
- (6)計算機軟件基本概念
- (7)進制的概念
- (8)計算機內部的數據表達
- (9)網絡編程基礎
- (10)Java語言簡介
- (11)JDK的獲得、安裝和配置
- (12)第一個HelloWorld程序
- (13)Eclipse基本使用
- (14)Eclipse基礎使用進階
- (15)如何學好Java語法
- (16)代碼框架、關鍵字和標識符
- (17)基本數據類型
- (18)變量和常量
- (19)數據類型轉換
- (20)空白、語句結束和注釋
- (21)算術運算符
- (22)比較運算符
- (23)邏輯運算符
- (24)賦值運算符
- (25)位運算符
- (26)移位運算符
- (27)其它運算符
- (28)運算符優先級
- (29)表達式
- (30)流程控制基礎
- (31)if語句語法(1)
- (32)if語句語法(2)
- (33)if語句語法(3)
- (34)switch語句語法
- (35)while語句語法
- (36)do-while語句語法
- (37)for語句語法
- (38)break和continue語句
- (39)流程控制綜合示例1
- (40)流程控制綜合示例2
- (41)流程控制綜合示例3
- (42)流程控制綜合練習
- (43)數組概述
- (44)數組基礎語法
- (45)數組使用示例1
- (46)數組使用示例2
- (47)數組使用示例3
- (48)多維數組基礎
- (49)多維數組使用示例1
- (50)多維數組使用示例2
- (51)多維數組練習
- (52)方法聲明
- (53)方法聲明示例
- (54)方法調用
- (55)方法重載和參數傳遞
- (56)方法練習
- (57)面向對象基礎
- (58)類(一)
- (59)類(二)
- (60)對象
- (61)面向對象設計方法和面向對象特性(一)
- (62)繼承(二)
- (63)多態性
- (64)訪問控制符、修飾符和其它關鍵字
- (65)static修飾符
- (66)final修飾符
- (67)this和super
- (68)抽象類和接口(一)
- (69)抽象類和接口(二)
- (70)抽象類和接口(三)
- (71)內部類簡介
- (72)包的概念
- (73)JDK文檔使用
- (74)java.lang包介紹1
- (75)String類使用
- (76)StringBuffer類和System類
- (77)包裝類
- (78)時間和日期處理
- (79)Random隨機處理
- (80)集合框架簡述
- (81)異常處理概述
- (82)異常處理語法1
- (83)異常處理語法2
- (84)IO簡介
- (85)IO類體系
- (86)文件操作之File類使用
- (87)文件操作之讀取文件
- (88)文件操作之寫文件
- (89)讀取控制臺輸入
- (90)裝飾流使用1
- (91)裝飾流使用2
- (92)IO使用注意問題
- (93)多線程基礎
- (94)多線程實現方式1
- (95)多線程實現方式2
- (96)多線程使用示例1
- (97)多線程使用示例2
- (98)多線程問題及處理1
- (99)多線程問題及處理2
- (100)多線程問題及處理3
- (101)網絡編程概述
- (102)網絡編程技術1
- (103)網絡編程技術2
- (104)網絡編程技術3
- (105)網絡編程技術4
- (106)網絡編程技術5
- (107)網絡協議概念
- (108)網絡編程示例1
- (109)網絡編程示例2
- (110)網絡編程小結